@deephaven/jsapi-utils 0.50.1-beta.5 → 0.51.1-alpha-theme-fix.1
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/ConnectionUtils.js.map +1 -1
- package/dist/DateUtils.js.map +1 -1
- package/dist/FilterUtils.js.map +1 -1
- package/dist/Formatter.js.map +1 -1
- package/dist/FormatterUtils.js.map +1 -1
- package/dist/MessageUtils.js.map +1 -1
- package/dist/NoConsolesError.js.map +1 -1
- package/dist/SessionUtils.js.map +1 -1
- package/dist/TableUtils.js.map +1 -1
- package/dist/ViewportDataUtils.js.map +1 -1
- package/dist/formatters/BooleanColumnFormatter.js.map +1 -1
- package/dist/formatters/CharColumnFormatter.js.map +1 -1
- package/dist/formatters/DateTimeColumnFormatter.js.map +1 -1
- package/dist/formatters/DecimalColumnFormatter.js.map +1 -1
- package/dist/formatters/DefaultColumnFormatter.js.map +1 -1
- package/dist/formatters/IntegerColumnFormatter.js.map +1 -1
- package/dist/formatters/StringColumnFormatter.js.map +1 -1
- package/dist/formatters/TableColumnFormatter.js.map +1 -1
- package/package.json +7 -7
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ConnectionUtils.js","names":["TimeoutError","FETCH_TIMEOUT","fetchVariableDefinition","connection","name","timeout","Promise","resolve","reject","removeListener","timeoutId","setTimeout","handleFieldUpdates","changes","definition","created","find","def","title","clearTimeout","subscribeToFieldUpdates"],"sources":["../src/ConnectionUtils.ts"],"sourcesContent":["import type {\n IdeConnection,\n VariableChanges,\n VariableDefinition,\n} from '@deephaven/jsapi-types';\nimport { TimeoutError } from '@deephaven/utils';\n\n/** Default timeout for fetching a variable definition */\nexport const FETCH_TIMEOUT = 10_000;\n\n/**\n * Fetch the definition for a variable given a connection. Subscribes to field updates and triggers when the variable is found.\n * @param connection Connection to get the variable from\n * @param name Name of the definition to fetch\n * @param timeout Timeout for the fetch\n * @returns Promise the resolves to the variable definition if found, or rejects if there's an error or the timeout has exceeded\n */\nexport function fetchVariableDefinition(\n connection: IdeConnection,\n name: string,\n timeout = FETCH_TIMEOUT\n): Promise<VariableDefinition> {\n return new Promise<VariableDefinition>((resolve, reject) => {\n let removeListener: () => void;\n\n const timeoutId = setTimeout(() => {\n removeListener?.();\n reject(new TimeoutError(`Variable ${name} not found`));\n }, timeout);\n\n /**\n * Checks if the variable we're looking for is in the changes, and resolves the promise if it does\n * @param changes Variables changes that have occurred\n */\n function handleFieldUpdates(changes: VariableChanges): void {\n const definition = changes.created.find(def => def.title === name);\n if (definition != null) {\n clearTimeout(timeoutId);\n removeListener?.();\n resolve(definition);\n }\n }\n\n removeListener = connection.subscribeToFieldUpdates(handleFieldUpdates);\n });\n}\n"],"mappings":"AAKA,SAASA,YAAY,QAAQ,kBAAkB;;AAE/C;AACA,OAAO,IAAMC,aAAa,GAAG,KAAM;;AAEnC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,SAASC,
|
|
1
|
+
{"version":3,"file":"ConnectionUtils.js","names":["TimeoutError","FETCH_TIMEOUT","fetchVariableDefinition","connection","name","timeout","arguments","length","undefined","Promise","resolve","reject","removeListener","timeoutId","setTimeout","_removeListener","concat","handleFieldUpdates","changes","definition","created","find","def","title","_removeListener2","clearTimeout","subscribeToFieldUpdates"],"sources":["../src/ConnectionUtils.ts"],"sourcesContent":["import type {\n IdeConnection,\n VariableChanges,\n VariableDefinition,\n} from '@deephaven/jsapi-types';\nimport { TimeoutError } from '@deephaven/utils';\n\n/** Default timeout for fetching a variable definition */\nexport const FETCH_TIMEOUT = 10_000;\n\n/**\n * Fetch the definition for a variable given a connection. Subscribes to field updates and triggers when the variable is found.\n * @param connection Connection to get the variable from\n * @param name Name of the definition to fetch\n * @param timeout Timeout for the fetch\n * @returns Promise the resolves to the variable definition if found, or rejects if there's an error or the timeout has exceeded\n */\nexport function fetchVariableDefinition(\n connection: IdeConnection,\n name: string,\n timeout = FETCH_TIMEOUT\n): Promise<VariableDefinition> {\n return new Promise<VariableDefinition>((resolve, reject) => {\n let removeListener: () => void;\n\n const timeoutId = setTimeout(() => {\n removeListener?.();\n reject(new TimeoutError(`Variable ${name} not found`));\n }, timeout);\n\n /**\n * Checks if the variable we're looking for is in the changes, and resolves the promise if it does\n * @param changes Variables changes that have occurred\n */\n function handleFieldUpdates(changes: VariableChanges): void {\n const definition = changes.created.find(def => def.title === name);\n if (definition != null) {\n clearTimeout(timeoutId);\n removeListener?.();\n resolve(definition);\n }\n }\n\n removeListener = connection.subscribeToFieldUpdates(handleFieldUpdates);\n });\n}\n"],"mappings":"AAKA,SAASA,YAAY,QAAQ,kBAAkB;;AAE/C;AACA,OAAO,IAAMC,aAAa,GAAG,KAAM;;AAEnC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,SAASC,uBAAuBA,CACrCC,UAAyB,EACzBC,IAAY,EAEiB;EAAA,IAD7BC,OAAO,GAAAC,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAGL,aAAa;EAEvB,OAAO,IAAIQ,OAAO,CAAqB,CAACC,OAAO,EAAEC,MAAM,KAAK;IAC1D,IAAIC,cAA0B;IAE9B,IAAMC,SAAS,GAAGC,UAAU,CAAC,MAAM;MAAA,IAAAC,eAAA;MACjC,CAAAA,eAAA,GAAAH,cAAc,cAAAG,eAAA,uBAAdA,eAAA,CAAiB,CAAC;MAClBJ,MAAM,CAAC,IAAIX,YAAY,aAAAgB,MAAA,CAAaZ,IAAI,eAAY,CAAC,CAAC;IACxD,CAAC,EAAEC,OAAO,CAAC;;IAEX;AACJ;AACA;AACA;IACI,SAASY,kBAAkBA,CAACC,OAAwB,EAAQ;MAC1D,IAAMC,UAAU,GAAGD,OAAO,CAACE,OAAO,CAACC,IAAI,CAACC,GAAG,IAAIA,GAAG,CAACC,KAAK,KAAKnB,IAAI,CAAC;MAClE,IAAIe,UAAU,IAAI,IAAI,EAAE;QAAA,IAAAK,gBAAA;QACtBC,YAAY,CAACZ,SAAS,CAAC;QACvB,CAAAW,gBAAA,GAAAZ,cAAc,cAAAY,gBAAA,uBAAdA,gBAAA,CAAiB,CAAC;QAClBd,OAAO,CAACS,UAAU,CAAC;MACrB;IACF;IAEAP,cAAc,GAAGT,UAAU,CAACuB,uBAAuB,CAACT,kBAAkB,CAAC;EACzE,CAAC,CAAC;AACJ"}
|
package/dist/DateUtils.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DateUtils.js","names":["DateUtils","makeDateWrapper","dh","timeZone","year","month","day","hour","minute","second","ns","Error","yearString","padStart","monthString","dayString","hourString","minuteString","secondString","nanoString","dateString","i18n","DateTimeFormat","parse","FULL_DATE_FORMAT","TimeZone","getTimeZone","getNextNanos","sigNanos","parseInt","zeros","repeat","length","nextNanoString","getNextDate","components","values","date","hours","minutes","seconds","nanos","jsDate","Date","getFullYear","getMonth","getDate","getHours","getMinutes","getSeconds","parseMonth","Number","isNaN","NaN","cleanMonthString","trim","toLowerCase","i","months","startsWith","parseDateValues","padEnd","parseDateTimeString","dateTimeString","regex","result","exec","overflow","parseDateRange","text","cleanText","now","startDate","tomorrow","endDate","yesterday","DateWrapper","ofJsDate","getJsDate","dateWrapper","asDate"],"sources":["../src/DateUtils.ts"],"sourcesContent":["import type { DateWrapper, dh as DhType } from '@deephaven/jsapi-types';\n\ninterface DateParts<T> {\n year: T;\n month: T;\n date: T;\n hours: T;\n minutes: T;\n seconds: T;\n nanos: T;\n}\n\nexport class DateUtils {\n static FULL_DATE_FORMAT = 'yyyy-MM-dd HH:mm:ss.SSSSSSSSS';\n\n static months = [\n 'january',\n 'february',\n 'march',\n 'april',\n 'may',\n 'june',\n 'july',\n 'august',\n 'september',\n 'october',\n 'november',\n 'december',\n ];\n\n /**\n *\n * @param timeZone The time zone to parse this time in. E.g. America/New_York\n * @param year The year for the date\n * @param month The month, starting at 0\n * @param day The day, starting at 1\n * @param hour The hours\n * @param minute The minutes\n * @param second The seconds\n * @param ns The nanoseconds\n */\n static makeDateWrapper(\n dh: DhType,\n timeZone: string,\n year: number,\n month = 0,\n day = 1,\n hour = 0,\n minute = 0,\n second = 0,\n ns = 0\n ): DateWrapper {\n if (!timeZone) {\n throw new Error('No timezone provided');\n }\n const yearString = `${year}`.padStart(4, '0');\n const monthString = `${month + 1}`.padStart(2, '0');\n const dayString = `${day}`.padStart(2, '0');\n const hourString = `${hour}`.padStart(2, '0');\n const minuteString = `${minute}`.padStart(2, '0');\n const secondString = `${second}`.padStart(2, '0');\n const nanoString = `${ns}`.padStart(9, '0');\n\n const dateString = `${yearString}-${monthString}-${dayString} ${hourString}:${minuteString}:${secondString}.${nanoString}`;\n return dh.i18n.DateTimeFormat.parse(\n DateUtils.FULL_DATE_FORMAT,\n dateString,\n dh.i18n.TimeZone.getTimeZone(timeZone)\n );\n }\n\n /**\n * Takes the string the user entered and returns the next nanos value\n * @param nanoString The nano string to get the next one of\n * @returns The value of the next nanos\n */\n static getNextNanos(nanoString: string): number {\n const sigNanos = parseInt(nanoString, 10);\n // Get the zeroes needed for padding before adding one so we handle overflow properly.\n const zeros = '0'.repeat(9 - nanoString.length);\n const nextNanoString = `${sigNanos + 1}${zeros}`;\n return parseInt(nextNanoString, 10);\n }\n\n /**\n * @param components The string components that were parsed from the original string\n * @param values The values that were parsed from the components\n * @param timeZone The time zone to parse the date in. E.g. America/New_York\n * @returns Returns the DateWrapper for the next date, or null if a full date was passed in\n */\n static getNextDate(\n dh: DhType,\n components: DateParts<string>,\n values: DateParts<number>,\n timeZone: string\n ): DateWrapper | null {\n let { year, month, date, hours, minutes, seconds, nanos } = values;\n\n if (components.nanos != null) {\n if (components.nanos.length === 9) {\n // They want an exact match\n return null;\n }\n nanos = DateUtils.getNextNanos(components.nanos);\n if (nanos > 999999999) {\n // There's an overflow, add it to the seconds manually\n seconds += 1;\n nanos = 0;\n }\n } else if (components.seconds != null) {\n seconds += 1;\n } else if (components.minutes != null) {\n minutes += 1;\n } else if (components.hours != null) {\n hours += 1;\n } else if (components.date != null) {\n date += 1;\n } else if (components.month != null) {\n month += 1;\n } else {\n year += 1;\n }\n\n // Use the JS date to handle overflow rather than doing our own logic\n // Because handling leap years and stuff is a pain\n // Still need to add nanos after, and the overflow from that is already added to seconds above\n const jsDate = new Date(year, month, date, hours, minutes, seconds);\n return DateUtils.makeDateWrapper(\n dh,\n timeZone,\n jsDate.getFullYear(),\n jsDate.getMonth(),\n jsDate.getDate(),\n jsDate.getHours(),\n jsDate.getMinutes(),\n jsDate.getSeconds(),\n nanos\n );\n }\n\n /**\n * Get the JS month value for the provided string.\n * Matches digits or a month name (eg. '1', '01', 'jan', 'january' should all work)\n * @param monthString The string to parse to a JS month value\n * @returns number The JS month value, which starts at 0 for january, or NaN if nothing could be parsed\n */\n static parseMonth(monthString: string): number {\n const month = parseInt(monthString, 10);\n if (!Number.isNaN(month)) {\n if (month >= 1 && month <= 12) {\n return month - 1;\n }\n return NaN;\n }\n\n const cleanMonthString = monthString.trim().toLowerCase();\n if (cleanMonthString.length >= 3) {\n for (let i = 0; i < DateUtils.months.length; i += 1) {\n if (DateUtils.months[i].startsWith(cleanMonthString)) {\n return i;\n }\n }\n }\n\n return NaN;\n }\n\n /**\n * Parse a date object out of the provided string segments.\n * Also using `parseMonth` to get month names like Aug/August rather than\n * simply doing `parseInt`.\n * @param yearString The year part of the string\n * @param monthString The month part of the string\n * @param dayString The day part of the string\n * @param hourString The hour part of the string\n * @param minuteString The minute part of the string\n * @param secondString The second part of the string\n * @param nanoString The milli part of the string\n */\n static parseDateValues(\n yearString: string,\n monthString: string,\n dayString: string,\n hourString: string,\n minuteString: string,\n secondString: string,\n nanoString: string\n ): DateParts<number> | null {\n const year = parseInt(yearString, 10);\n const month = monthString != null ? this.parseMonth(monthString) : 0;\n const date = dayString != null ? parseInt(dayString, 10) : 1;\n const hours = hourString != null ? parseInt(hourString, 10) : 0;\n const minutes = minuteString != null ? parseInt(minuteString, 10) : 0;\n const seconds = secondString != null ? parseInt(secondString, 10) : 0;\n const nanos =\n nanoString != null ? parseInt(nanoString.padEnd(9, '0'), 10) : 0;\n if (\n Number.isNaN(year) ||\n Number.isNaN(month) ||\n Number.isNaN(date) ||\n Number.isNaN(hours) ||\n Number.isNaN(minutes) ||\n Number.isNaN(seconds) ||\n Number.isNaN(nanos)\n ) {\n return null;\n }\n\n return { year, month, date, hours, minutes, seconds, nanos };\n }\n\n /**\n * Parse out a date time string into it's string components.\n * Anything that is not captured in the string will be undefined.\n *\n * @param dateTimeString The date time string to parse\n * @returns Containing the date time components\n */\n static parseDateTimeString(dateTimeString: string): DateParts<string> {\n const regex =\n /\\s*(\\d{4})([-./]([\\da-z]+))?([-./](\\d{1,2}))?([tT\\s](\\d{2})([:](\\d{2}))?([:](\\d{2}))?([.](\\d{1,9}))?)?(.*)/;\n const result = regex.exec(dateTimeString);\n if (result == null) {\n throw new Error(`Unexpected date string: ${dateTimeString}`);\n }\n\n const [\n ,\n year,\n ,\n month,\n ,\n date,\n ,\n hours,\n ,\n minutes,\n ,\n seconds,\n ,\n nanos,\n overflow,\n ] = result;\n if (overflow != null && overflow.length > 0) {\n throw new Error(\n `Unexpected characters after date string '${dateTimeString}': ${overflow}`\n );\n }\n\n return { year, month, date, hours, minutes, seconds, nanos };\n }\n\n /**\n * Parses the date range provided from a string of text.\n * @param text The string to parse the date from. Can be a keyword like \"today\", or in the format \"2018-08-04\"\n * @param timeZone The time zone to parse this range in. E.g. America/New_York\n * @returns A tuple with the start and end value/null for that date range, or both null\n */\n static parseDateRange(\n dh: DhType,\n text: string,\n timeZone: string\n ): [DateWrapper, DateWrapper | null] | [null, null] {\n const cleanText = text.trim().toLowerCase();\n if (cleanText.length === 0) {\n throw new Error('Cannot parse date range from empty string');\n }\n\n if (cleanText === 'null') {\n return [null, null];\n }\n\n if (cleanText === 'today') {\n const now = new Date(Date.now());\n const startDate = DateUtils.makeDateWrapper(\n dh,\n timeZone,\n now.getFullYear(),\n now.getMonth(),\n now.getDate()\n );\n const tomorrow = new Date(\n now.getFullYear(),\n now.getMonth(),\n now.getDate() + 1\n );\n const endDate = DateUtils.makeDateWrapper(\n dh,\n timeZone,\n tomorrow.getFullYear(),\n tomorrow.getMonth(),\n tomorrow.getDate()\n );\n return [startDate, endDate];\n }\n\n if (cleanText === 'yesterday') {\n const now = new Date(Date.now());\n const yesterday = new Date(\n now.getFullYear(),\n now.getMonth(),\n now.getDate() - 1\n );\n const startDate = DateUtils.makeDateWrapper(\n dh,\n timeZone,\n yesterday.getFullYear(),\n yesterday.getMonth(),\n yesterday.getDate()\n );\n const endDate = DateUtils.makeDateWrapper(\n dh,\n timeZone,\n now.getFullYear(),\n now.getMonth(),\n now.getDate()\n );\n return [startDate, endDate];\n }\n\n if (cleanText === 'now') {\n const now = new Date(Date.now());\n const date = dh.DateWrapper.ofJsDate(now);\n return [date, null];\n }\n\n const components = DateUtils.parseDateTimeString(cleanText);\n if (\n components.year == null &&\n components.month == null &&\n components.date == null\n ) {\n throw new Error(`Unable to extract year, month, or day ${cleanText}`);\n }\n\n const values = DateUtils.parseDateValues(\n components.year,\n components.month,\n components.date,\n components.hours,\n components.minutes,\n components.seconds,\n components.nanos\n );\n\n if (values == null) {\n throw new Error(`Unable to extract date values from ${components}`);\n }\n\n const startDate = DateUtils.makeDateWrapper(\n dh,\n timeZone,\n values.year,\n values.month,\n values.date,\n values.hours,\n values.minutes,\n values.seconds,\n values.nanos\n );\n\n const endDate = DateUtils.getNextDate(dh, components, values, timeZone);\n return [startDate, endDate];\n }\n\n /**\n * Gets the Js Date object from the provided DateWrapper.\n * In unit test, DateWrapper is just a number provided in millis, so handles that case.\n * @param dateWrapper The DateWrapper object, or time in millis\n */\n static getJsDate(dateWrapper: DateWrapper | number): Date {\n if (typeof dateWrapper === 'number') {\n return new Date(dateWrapper);\n }\n return dateWrapper.asDate();\n }\n}\n\nexport default DateUtils;\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"DateUtils.js","names":["DateUtils","makeDateWrapper","dh","timeZone","year","month","arguments","length","undefined","day","hour","minute","second","ns","Error","yearString","concat","padStart","monthString","dayString","hourString","minuteString","secondString","nanoString","dateString","i18n","DateTimeFormat","parse","FULL_DATE_FORMAT","TimeZone","getTimeZone","getNextNanos","sigNanos","parseInt","zeros","repeat","nextNanoString","getNextDate","components","values","date","hours","minutes","seconds","nanos","jsDate","Date","getFullYear","getMonth","getDate","getHours","getMinutes","getSeconds","parseMonth","Number","isNaN","NaN","cleanMonthString","trim","toLowerCase","i","months","startsWith","parseDateValues","padEnd","parseDateTimeString","dateTimeString","regex","result","exec","overflow","parseDateRange","text","cleanText","now","startDate","tomorrow","endDate","yesterday","DateWrapper","ofJsDate","getJsDate","dateWrapper","asDate","_defineProperty"],"sources":["../src/DateUtils.ts"],"sourcesContent":["import type { DateWrapper, dh as DhType } from '@deephaven/jsapi-types';\n\ninterface DateParts<T> {\n year: T;\n month: T;\n date: T;\n hours: T;\n minutes: T;\n seconds: T;\n nanos: T;\n}\n\nexport class DateUtils {\n static FULL_DATE_FORMAT = 'yyyy-MM-dd HH:mm:ss.SSSSSSSSS';\n\n static months = [\n 'january',\n 'february',\n 'march',\n 'april',\n 'may',\n 'june',\n 'july',\n 'august',\n 'september',\n 'october',\n 'november',\n 'december',\n ];\n\n /**\n *\n * @param timeZone The time zone to parse this time in. E.g. America/New_York\n * @param year The year for the date\n * @param month The month, starting at 0\n * @param day The day, starting at 1\n * @param hour The hours\n * @param minute The minutes\n * @param second The seconds\n * @param ns The nanoseconds\n */\n static makeDateWrapper(\n dh: DhType,\n timeZone: string,\n year: number,\n month = 0,\n day = 1,\n hour = 0,\n minute = 0,\n second = 0,\n ns = 0\n ): DateWrapper {\n if (!timeZone) {\n throw new Error('No timezone provided');\n }\n const yearString = `${year}`.padStart(4, '0');\n const monthString = `${month + 1}`.padStart(2, '0');\n const dayString = `${day}`.padStart(2, '0');\n const hourString = `${hour}`.padStart(2, '0');\n const minuteString = `${minute}`.padStart(2, '0');\n const secondString = `${second}`.padStart(2, '0');\n const nanoString = `${ns}`.padStart(9, '0');\n\n const dateString = `${yearString}-${monthString}-${dayString} ${hourString}:${minuteString}:${secondString}.${nanoString}`;\n return dh.i18n.DateTimeFormat.parse(\n DateUtils.FULL_DATE_FORMAT,\n dateString,\n dh.i18n.TimeZone.getTimeZone(timeZone)\n );\n }\n\n /**\n * Takes the string the user entered and returns the next nanos value\n * @param nanoString The nano string to get the next one of\n * @returns The value of the next nanos\n */\n static getNextNanos(nanoString: string): number {\n const sigNanos = parseInt(nanoString, 10);\n // Get the zeroes needed for padding before adding one so we handle overflow properly.\n const zeros = '0'.repeat(9 - nanoString.length);\n const nextNanoString = `${sigNanos + 1}${zeros}`;\n return parseInt(nextNanoString, 10);\n }\n\n /**\n * @param components The string components that were parsed from the original string\n * @param values The values that were parsed from the components\n * @param timeZone The time zone to parse the date in. E.g. America/New_York\n * @returns Returns the DateWrapper for the next date, or null if a full date was passed in\n */\n static getNextDate(\n dh: DhType,\n components: DateParts<string>,\n values: DateParts<number>,\n timeZone: string\n ): DateWrapper | null {\n let { year, month, date, hours, minutes, seconds, nanos } = values;\n\n if (components.nanos != null) {\n if (components.nanos.length === 9) {\n // They want an exact match\n return null;\n }\n nanos = DateUtils.getNextNanos(components.nanos);\n if (nanos > 999999999) {\n // There's an overflow, add it to the seconds manually\n seconds += 1;\n nanos = 0;\n }\n } else if (components.seconds != null) {\n seconds += 1;\n } else if (components.minutes != null) {\n minutes += 1;\n } else if (components.hours != null) {\n hours += 1;\n } else if (components.date != null) {\n date += 1;\n } else if (components.month != null) {\n month += 1;\n } else {\n year += 1;\n }\n\n // Use the JS date to handle overflow rather than doing our own logic\n // Because handling leap years and stuff is a pain\n // Still need to add nanos after, and the overflow from that is already added to seconds above\n const jsDate = new Date(year, month, date, hours, minutes, seconds);\n return DateUtils.makeDateWrapper(\n dh,\n timeZone,\n jsDate.getFullYear(),\n jsDate.getMonth(),\n jsDate.getDate(),\n jsDate.getHours(),\n jsDate.getMinutes(),\n jsDate.getSeconds(),\n nanos\n );\n }\n\n /**\n * Get the JS month value for the provided string.\n * Matches digits or a month name (eg. '1', '01', 'jan', 'january' should all work)\n * @param monthString The string to parse to a JS month value\n * @returns number The JS month value, which starts at 0 for january, or NaN if nothing could be parsed\n */\n static parseMonth(monthString: string): number {\n const month = parseInt(monthString, 10);\n if (!Number.isNaN(month)) {\n if (month >= 1 && month <= 12) {\n return month - 1;\n }\n return NaN;\n }\n\n const cleanMonthString = monthString.trim().toLowerCase();\n if (cleanMonthString.length >= 3) {\n for (let i = 0; i < DateUtils.months.length; i += 1) {\n if (DateUtils.months[i].startsWith(cleanMonthString)) {\n return i;\n }\n }\n }\n\n return NaN;\n }\n\n /**\n * Parse a date object out of the provided string segments.\n * Also using `parseMonth` to get month names like Aug/August rather than\n * simply doing `parseInt`.\n * @param yearString The year part of the string\n * @param monthString The month part of the string\n * @param dayString The day part of the string\n * @param hourString The hour part of the string\n * @param minuteString The minute part of the string\n * @param secondString The second part of the string\n * @param nanoString The milli part of the string\n */\n static parseDateValues(\n yearString: string,\n monthString: string,\n dayString: string,\n hourString: string,\n minuteString: string,\n secondString: string,\n nanoString: string\n ): DateParts<number> | null {\n const year = parseInt(yearString, 10);\n const month = monthString != null ? this.parseMonth(monthString) : 0;\n const date = dayString != null ? parseInt(dayString, 10) : 1;\n const hours = hourString != null ? parseInt(hourString, 10) : 0;\n const minutes = minuteString != null ? parseInt(minuteString, 10) : 0;\n const seconds = secondString != null ? parseInt(secondString, 10) : 0;\n const nanos =\n nanoString != null ? parseInt(nanoString.padEnd(9, '0'), 10) : 0;\n if (\n Number.isNaN(year) ||\n Number.isNaN(month) ||\n Number.isNaN(date) ||\n Number.isNaN(hours) ||\n Number.isNaN(minutes) ||\n Number.isNaN(seconds) ||\n Number.isNaN(nanos)\n ) {\n return null;\n }\n\n return { year, month, date, hours, minutes, seconds, nanos };\n }\n\n /**\n * Parse out a date time string into it's string components.\n * Anything that is not captured in the string will be undefined.\n *\n * @param dateTimeString The date time string to parse\n * @returns Containing the date time components\n */\n static parseDateTimeString(dateTimeString: string): DateParts<string> {\n const regex =\n /\\s*(\\d{4})([-./]([\\da-z]+))?([-./](\\d{1,2}))?([tT\\s](\\d{2})([:](\\d{2}))?([:](\\d{2}))?([.](\\d{1,9}))?)?(.*)/;\n const result = regex.exec(dateTimeString);\n if (result == null) {\n throw new Error(`Unexpected date string: ${dateTimeString}`);\n }\n\n const [\n ,\n year,\n ,\n month,\n ,\n date,\n ,\n hours,\n ,\n minutes,\n ,\n seconds,\n ,\n nanos,\n overflow,\n ] = result;\n if (overflow != null && overflow.length > 0) {\n throw new Error(\n `Unexpected characters after date string '${dateTimeString}': ${overflow}`\n );\n }\n\n return { year, month, date, hours, minutes, seconds, nanos };\n }\n\n /**\n * Parses the date range provided from a string of text.\n * @param text The string to parse the date from. Can be a keyword like \"today\", or in the format \"2018-08-04\"\n * @param timeZone The time zone to parse this range in. E.g. America/New_York\n * @returns A tuple with the start and end value/null for that date range, or both null\n */\n static parseDateRange(\n dh: DhType,\n text: string,\n timeZone: string\n ): [DateWrapper, DateWrapper | null] | [null, null] {\n const cleanText = text.trim().toLowerCase();\n if (cleanText.length === 0) {\n throw new Error('Cannot parse date range from empty string');\n }\n\n if (cleanText === 'null') {\n return [null, null];\n }\n\n if (cleanText === 'today') {\n const now = new Date(Date.now());\n const startDate = DateUtils.makeDateWrapper(\n dh,\n timeZone,\n now.getFullYear(),\n now.getMonth(),\n now.getDate()\n );\n const tomorrow = new Date(\n now.getFullYear(),\n now.getMonth(),\n now.getDate() + 1\n );\n const endDate = DateUtils.makeDateWrapper(\n dh,\n timeZone,\n tomorrow.getFullYear(),\n tomorrow.getMonth(),\n tomorrow.getDate()\n );\n return [startDate, endDate];\n }\n\n if (cleanText === 'yesterday') {\n const now = new Date(Date.now());\n const yesterday = new Date(\n now.getFullYear(),\n now.getMonth(),\n now.getDate() - 1\n );\n const startDate = DateUtils.makeDateWrapper(\n dh,\n timeZone,\n yesterday.getFullYear(),\n yesterday.getMonth(),\n yesterday.getDate()\n );\n const endDate = DateUtils.makeDateWrapper(\n dh,\n timeZone,\n now.getFullYear(),\n now.getMonth(),\n now.getDate()\n );\n return [startDate, endDate];\n }\n\n if (cleanText === 'now') {\n const now = new Date(Date.now());\n const date = dh.DateWrapper.ofJsDate(now);\n return [date, null];\n }\n\n const components = DateUtils.parseDateTimeString(cleanText);\n if (\n components.year == null &&\n components.month == null &&\n components.date == null\n ) {\n throw new Error(`Unable to extract year, month, or day ${cleanText}`);\n }\n\n const values = DateUtils.parseDateValues(\n components.year,\n components.month,\n components.date,\n components.hours,\n components.minutes,\n components.seconds,\n components.nanos\n );\n\n if (values == null) {\n throw new Error(`Unable to extract date values from ${components}`);\n }\n\n const startDate = DateUtils.makeDateWrapper(\n dh,\n timeZone,\n values.year,\n values.month,\n values.date,\n values.hours,\n values.minutes,\n values.seconds,\n values.nanos\n );\n\n const endDate = DateUtils.getNextDate(dh, components, values, timeZone);\n return [startDate, endDate];\n }\n\n /**\n * Gets the Js Date object from the provided DateWrapper.\n * In unit test, DateWrapper is just a number provided in millis, so handles that case.\n * @param dateWrapper The DateWrapper object, or time in millis\n */\n static getJsDate(dateWrapper: DateWrapper | number): Date {\n if (typeof dateWrapper === 'number') {\n return new Date(dateWrapper);\n }\n return dateWrapper.asDate();\n }\n}\n\nexport default DateUtils;\n"],"mappings":"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"}
|
package/dist/FilterUtils.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"FilterUtils.js","names":["createComboboxFilterArgs","value","allValue","operator","createSearchTextFilter","tableUtils","columnNames","searchText","searchTextFilter","maybeTable","searchTextTrimmed","trim","factory","createFilterConditionFactory","col","filter","containsIgnoreCase","makeFilterValue","type","createColumnCondition","conditionOperator","filterConditionFactory","maybeColumns","findColumns","length","filterConditions","map","reduce","current","next","createValueFilter","createSelectedValuesFilter","columnName","selection","emptySelectionEqAll","invertSelection","selectedValuesFilter","maybeColumn","findColumn","isAllSelected","size","makeSelectValueFilter","keys","createNotNullOrEmptyFilterCondition","notNullOrEmptyFilterCondition","column","isNull","not","and","notEq","createShowOnlyEmptyFilterCondition","isOn","showOnlyEmptyFilterCondition","emptyStringValue","eqEmptyStringCondition","eq","or"],"sources":["../src/FilterUtils.ts"],"sourcesContent":["import type {\n Column,\n FilterCondition,\n Table,\n TreeTable,\n} from '@deephaven/jsapi-types';\nimport type { SelectionT } from '@deephaven/utils';\nimport TableUtils from './TableUtils';\n\nexport interface FilterConditionFactory {\n (table: Table | TreeTable | null | undefined): FilterCondition | null;\n}\n\n/**\n * Create args for a filter derived from a combobox selection.\n * @param value\n */\nexport function createComboboxFilterArgs(\n value: string,\n allValue: string\n): {\n operator: 'eq' | 'notEq';\n value: string;\n} {\n return value === allValue\n ? { operator: 'notEq', value: '' } // this is synonymous with \"no filter\"\n : { operator: 'eq', value };\n}\n\n/**\n * Create a filter condition factory for a `contains` filter that matches the\n * given search text.\n * @param tableUtils TableUtils instance to create filter from\n * @param columnNames Names of the columns to filter\n * @param searchText Text to search (will be trimmed of leading / trailing whitespace)\n */\nexport function createSearchTextFilter(\n tableUtils: TableUtils,\n columnNames: string | string[],\n searchText: string\n): FilterConditionFactory {\n /**\n * Creates a filter condition that matches based on search text.\n * @param maybeTable Table to filter\n */\n return function searchTextFilter(\n maybeTable: Table | TreeTable | null | undefined\n ): FilterCondition | null {\n const searchTextTrimmed = searchText.trim();\n\n if (searchTextTrimmed === '') {\n return null;\n }\n\n const factory = createFilterConditionFactory(\n columnNames,\n col =>\n col\n .filter()\n .containsIgnoreCase(\n tableUtils.makeFilterValue(col.type, searchTextTrimmed)\n ),\n 'or'\n );\n\n return factory(maybeTable);\n };\n}\n\n/**\n * Create a filter condition factory function.\n * @param columnNames Column names that filter conditions will target\n * @param createColumnCondition Function that can create a `FilterCondition` from\n * a given column. This will be run across all columns corresponding to the given\n * list of column names.\n * @param conditionOperator Operator that will be used to combine multiple\n * `FilterConditions` if multiple column names are given.\n */\nexport function createFilterConditionFactory(\n columnNames: string | string[],\n createColumnCondition: (column: Column) => FilterCondition,\n conditionOperator: 'and' | 'or' = 'or'\n): FilterConditionFactory {\n return function filterConditionFactory(\n maybeTable: Table | TreeTable | null | undefined\n ): FilterCondition | null {\n const maybeColumns = maybeTable?.findColumns(\n typeof columnNames === 'string' ? [columnNames] : columnNames\n );\n\n if (maybeColumns == null || maybeColumns.length === 0) {\n return null;\n }\n\n const filterConditions = maybeColumns.map(createColumnCondition);\n\n return filterConditions.reduce((current, next) =>\n current[conditionOperator](next)\n );\n };\n}\n\n/**\n * Create a filter condition factory for a filter operator that matches the\n * given value.\n * @param tableUtils TableUtils instance to create filter from\n * @param columnNames Column names to compare value to\n * @param value Value to match\n * @param operator Operator to use for matching\n */\nexport function createValueFilter(\n tableUtils: TableUtils,\n columnNames: string | string[],\n value: string,\n operator:\n | 'contains'\n | 'containsIgnoreCase'\n | 'eq'\n | 'eqIgnoreCase'\n | 'notEq'\n | 'notEqIgnoreCase'\n): FilterConditionFactory {\n /**\n * Creates a filter condition that matches based on matching a given value.\n * @param maybeTable Table to filter\n */\n return createFilterConditionFactory(\n columnNames,\n col => col.filter()[operator](tableUtils.makeFilterValue(col.type, value)),\n 'or'\n );\n}\n\n/**\n * Create a filter condition factory for a filter that matches a given Selection.\n * If column is not found or selection parameter is 'all', the factory will return\n * null to indicate the results will be unfiltered.\n * @param tableUtils TableUtils instance to create filter from\n * @param columnName The column name to filter\n * @param selection 'all' or an array of values to filter by\n * @param emptySelectionEqAll If true, empty selection means select\n * all. If false, it means select none.\n * @param invertSelection Invert the selection (eg. All items are selected,\n * then you deselect items)\n */\nexport function createSelectedValuesFilter<TValue>(\n tableUtils: TableUtils,\n columnName: string,\n selection: SelectionT<TValue>,\n emptySelectionEqAll: boolean,\n invertSelection: boolean\n): FilterConditionFactory {\n /**\n * Creates a filter condition that matches rows for selected values. Returns\n * null to indicate no filtering.\n * @param maybeTable the table to filter\n */\n return function selectedValuesFilter(\n maybeTable: Table | TreeTable | null | undefined\n ): FilterCondition | null {\n const maybeColumn = maybeTable?.findColumn(columnName);\n\n const isAllSelected =\n selection === 'all' || (emptySelectionEqAll && selection.size === 0);\n\n if (maybeColumn == null || isAllSelected) {\n return null;\n }\n\n return tableUtils.makeSelectValueFilter(\n maybeColumn,\n [...selection.keys()],\n invertSelection\n );\n };\n}\n\n/**\n * Creates a `notNullOrEmptyFilterCondition` function.\n * @param tableUtils TableUtils instance to use for making filters.\n */\nexport function createNotNullOrEmptyFilterCondition(tableUtils: TableUtils) {\n /**\n * Returns a filter condition that matches values in a given column that are\n * not null or empty string.\n */\n return function notNullOrEmptyFilterCondition(\n column: Column\n ): FilterCondition {\n return column\n .filter()\n .isNull()\n .not()\n .and(column.filter().notEq(tableUtils.makeFilterValue(column.type, '')));\n };\n}\n\n/**\n * Creates a `showOnlyEmptyFilterCondition` function that can be toggled on or\n * off.\n * @param tableUtils TableUtils instance to use for making filters.\n * @param isOn Flag to indicate if the filter should be on or off.\n */\nexport function createShowOnlyEmptyFilterCondition(\n tableUtils: TableUtils,\n isOn: boolean\n) {\n /**\n * Returns a filter condition that matches values in a given column. If the\n * `isOn` param is true, this will filter to only null or empty string values.\n * If `isOn` is false, it will return a filter that matches all values.\n */\n return function showOnlyEmptyFilterCondition(\n column: Column\n ): FilterCondition {\n const filter = column.filter();\n const emptyStringValue = tableUtils.makeFilterValue(column.type, '');\n const eqEmptyStringCondition = filter.eq(emptyStringValue);\n\n if (isOn) {\n return filter.isNull().or(eqEmptyStringCondition);\n }\n\n // If filter is off, return a condition that will always be true\n return eqEmptyStringCondition.or(filter.notEq(emptyStringValue));\n };\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"FilterUtils.js","names":["createComboboxFilterArgs","value","allValue","operator","createSearchTextFilter","tableUtils","columnNames","searchText","searchTextFilter","maybeTable","searchTextTrimmed","trim","factory","createFilterConditionFactory","col","filter","containsIgnoreCase","makeFilterValue","type","createColumnCondition","conditionOperator","arguments","length","undefined","filterConditionFactory","maybeColumns","findColumns","filterConditions","map","reduce","current","next","createValueFilter","createSelectedValuesFilter","columnName","selection","emptySelectionEqAll","invertSelection","selectedValuesFilter","maybeColumn","findColumn","isAllSelected","size","makeSelectValueFilter","keys","createNotNullOrEmptyFilterCondition","notNullOrEmptyFilterCondition","column","isNull","not","and","notEq","createShowOnlyEmptyFilterCondition","isOn","showOnlyEmptyFilterCondition","emptyStringValue","eqEmptyStringCondition","eq","or"],"sources":["../src/FilterUtils.ts"],"sourcesContent":["import type {\n Column,\n FilterCondition,\n Table,\n TreeTable,\n} from '@deephaven/jsapi-types';\nimport type { SelectionT } from '@deephaven/utils';\nimport TableUtils from './TableUtils';\n\nexport interface FilterConditionFactory {\n (table: Table | TreeTable | null | undefined): FilterCondition | null;\n}\n\n/**\n * Create args for a filter derived from a combobox selection.\n * @param value\n */\nexport function createComboboxFilterArgs(\n value: string,\n allValue: string\n): {\n operator: 'eq' | 'notEq';\n value: string;\n} {\n return value === allValue\n ? { operator: 'notEq', value: '' } // this is synonymous with \"no filter\"\n : { operator: 'eq', value };\n}\n\n/**\n * Create a filter condition factory for a `contains` filter that matches the\n * given search text.\n * @param tableUtils TableUtils instance to create filter from\n * @param columnNames Names of the columns to filter\n * @param searchText Text to search (will be trimmed of leading / trailing whitespace)\n */\nexport function createSearchTextFilter(\n tableUtils: TableUtils,\n columnNames: string | string[],\n searchText: string\n): FilterConditionFactory {\n /**\n * Creates a filter condition that matches based on search text.\n * @param maybeTable Table to filter\n */\n return function searchTextFilter(\n maybeTable: Table | TreeTable | null | undefined\n ): FilterCondition | null {\n const searchTextTrimmed = searchText.trim();\n\n if (searchTextTrimmed === '') {\n return null;\n }\n\n const factory = createFilterConditionFactory(\n columnNames,\n col =>\n col\n .filter()\n .containsIgnoreCase(\n tableUtils.makeFilterValue(col.type, searchTextTrimmed)\n ),\n 'or'\n );\n\n return factory(maybeTable);\n };\n}\n\n/**\n * Create a filter condition factory function.\n * @param columnNames Column names that filter conditions will target\n * @param createColumnCondition Function that can create a `FilterCondition` from\n * a given column. This will be run across all columns corresponding to the given\n * list of column names.\n * @param conditionOperator Operator that will be used to combine multiple\n * `FilterConditions` if multiple column names are given.\n */\nexport function createFilterConditionFactory(\n columnNames: string | string[],\n createColumnCondition: (column: Column) => FilterCondition,\n conditionOperator: 'and' | 'or' = 'or'\n): FilterConditionFactory {\n return function filterConditionFactory(\n maybeTable: Table | TreeTable | null | undefined\n ): FilterCondition | null {\n const maybeColumns = maybeTable?.findColumns(\n typeof columnNames === 'string' ? [columnNames] : columnNames\n );\n\n if (maybeColumns == null || maybeColumns.length === 0) {\n return null;\n }\n\n const filterConditions = maybeColumns.map(createColumnCondition);\n\n return filterConditions.reduce((current, next) =>\n current[conditionOperator](next)\n );\n };\n}\n\n/**\n * Create a filter condition factory for a filter operator that matches the\n * given value.\n * @param tableUtils TableUtils instance to create filter from\n * @param columnNames Column names to compare value to\n * @param value Value to match\n * @param operator Operator to use for matching\n */\nexport function createValueFilter(\n tableUtils: TableUtils,\n columnNames: string | string[],\n value: string,\n operator:\n | 'contains'\n | 'containsIgnoreCase'\n | 'eq'\n | 'eqIgnoreCase'\n | 'notEq'\n | 'notEqIgnoreCase'\n): FilterConditionFactory {\n /**\n * Creates a filter condition that matches based on matching a given value.\n * @param maybeTable Table to filter\n */\n return createFilterConditionFactory(\n columnNames,\n col => col.filter()[operator](tableUtils.makeFilterValue(col.type, value)),\n 'or'\n );\n}\n\n/**\n * Create a filter condition factory for a filter that matches a given Selection.\n * If column is not found or selection parameter is 'all', the factory will return\n * null to indicate the results will be unfiltered.\n * @param tableUtils TableUtils instance to create filter from\n * @param columnName The column name to filter\n * @param selection 'all' or an array of values to filter by\n * @param emptySelectionEqAll If true, empty selection means select\n * all. If false, it means select none.\n * @param invertSelection Invert the selection (eg. All items are selected,\n * then you deselect items)\n */\nexport function createSelectedValuesFilter<TValue>(\n tableUtils: TableUtils,\n columnName: string,\n selection: SelectionT<TValue>,\n emptySelectionEqAll: boolean,\n invertSelection: boolean\n): FilterConditionFactory {\n /**\n * Creates a filter condition that matches rows for selected values. Returns\n * null to indicate no filtering.\n * @param maybeTable the table to filter\n */\n return function selectedValuesFilter(\n maybeTable: Table | TreeTable | null | undefined\n ): FilterCondition | null {\n const maybeColumn = maybeTable?.findColumn(columnName);\n\n const isAllSelected =\n selection === 'all' || (emptySelectionEqAll && selection.size === 0);\n\n if (maybeColumn == null || isAllSelected) {\n return null;\n }\n\n return tableUtils.makeSelectValueFilter(\n maybeColumn,\n [...selection.keys()],\n invertSelection\n );\n };\n}\n\n/**\n * Creates a `notNullOrEmptyFilterCondition` function.\n * @param tableUtils TableUtils instance to use for making filters.\n */\nexport function createNotNullOrEmptyFilterCondition(tableUtils: TableUtils) {\n /**\n * Returns a filter condition that matches values in a given column that are\n * not null or empty string.\n */\n return function notNullOrEmptyFilterCondition(\n column: Column\n ): FilterCondition {\n return column\n .filter()\n .isNull()\n .not()\n .and(column.filter().notEq(tableUtils.makeFilterValue(column.type, '')));\n };\n}\n\n/**\n * Creates a `showOnlyEmptyFilterCondition` function that can be toggled on or\n * off.\n * @param tableUtils TableUtils instance to use for making filters.\n * @param isOn Flag to indicate if the filter should be on or off.\n */\nexport function createShowOnlyEmptyFilterCondition(\n tableUtils: TableUtils,\n isOn: boolean\n) {\n /**\n * Returns a filter condition that matches values in a given column. If the\n * `isOn` param is true, this will filter to only null or empty string values.\n * If `isOn` is false, it will return a filter that matches all values.\n */\n return function showOnlyEmptyFilterCondition(\n column: Column\n ): FilterCondition {\n const filter = column.filter();\n const emptyStringValue = tableUtils.makeFilterValue(column.type, '');\n const eqEmptyStringCondition = filter.eq(emptyStringValue);\n\n if (isOn) {\n return filter.isNull().or(eqEmptyStringCondition);\n }\n\n // If filter is off, return a condition that will always be true\n return eqEmptyStringCondition.or(filter.notEq(emptyStringValue));\n };\n}\n"],"mappings":"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"}
|
package/dist/Formatter.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Formatter.js","names":["TableUtils","BooleanColumnFormatter","CharColumnFormatter","DateTimeColumnFormatter","DecimalColumnFormatter","DefaultColumnFormatter","IntegerColumnFormatter","StringColumnFormatter","Formatter","makeColumnFormatMap","columnFormattingRules","Map","reduce","map","next","dataType","getNormalizedType","columnType","has","set","formatMap","get","columnName","format","makeColumnFormattingRule","constructor","dh","dateTimeOptions","decimalFormatOptions","integerFormatOptions","truncateNumbersWithPound","defaultColumnFormatter","typeFormatterMap","BOOLEAN","CHAR","DATETIME","DECIMAL","INT","STRING","columnFormatMap","getColumnFormatMapForType","createIfNecessary","undefined","getColumnFormat","getColumnTypeFormatter","columnTypeFormatter","getFormattedString","value","formatOverride","formatter","timeZone","dhTimeZone","id"],"sources":["../src/Formatter.ts"],"sourcesContent":["import type { dh as DhType } from '@deephaven/jsapi-types';\nimport TableUtils, { DataType } from './TableUtils';\nimport {\n BooleanColumnFormatter,\n CharColumnFormatter,\n DateTimeColumnFormatter,\n DecimalColumnFormatter,\n DefaultColumnFormatter,\n IntegerColumnFormatter,\n StringColumnFormatter,\n TableColumnFormat,\n TableColumnFormatter,\n} from './formatters';\n\nexport type ColumnName = string;\n\nexport interface FormattingRule {\n columnType: string;\n columnName: ColumnName;\n format: TableColumnFormat;\n}\n\nexport class Formatter {\n /**\n * Converts FormattingRule[] to Map\n * @param columnFormattingRules Array or column formatting rules\n * @returns Map of columnName-to-format Maps indexed by normalized dataType\n */\n static makeColumnFormatMap(\n columnFormattingRules: FormattingRule[]\n ): Map<DataType, Map<ColumnName, TableColumnFormat>> {\n if (columnFormattingRules == null) {\n return new Map();\n }\n return columnFormattingRules.reduce((map, next) => {\n const dataType = TableUtils.getNormalizedType(next.columnType);\n if (dataType === null) {\n return map;\n }\n\n if (!map.has(dataType)) {\n map.set(dataType, new Map());\n }\n const formatMap = map.get(dataType);\n formatMap?.set(next.columnName, next.format);\n return map;\n }, new Map<DataType, Map<ColumnName, TableColumnFormat>>());\n }\n\n /**\n * Creates a column formatting rule\n * @param columnType Normalized data type\n * @param columnName Column name\n * @param format Format object\n */\n static makeColumnFormattingRule(\n columnType: DataType,\n columnName: ColumnName,\n format: TableColumnFormat\n ): FormattingRule {\n return {\n columnType,\n columnName,\n format,\n };\n }\n\n /**\n * @param dh JSAPI instance\n * @param columnFormattingRules Optional array of column formatting rules\n * @param dateTimeOptions Optional object with DateTime configuration\n * @param decimalFormatOptions Optional object with Decimal configuration\n * @param integerFormatOptions Optional object with Integer configuration\n * @param truncateNumbersWithPound Determine if numbers should be truncated w/ repeating # instead of ellipsis at the end\n */\n constructor(\n dh: DhType,\n columnFormattingRules: FormattingRule[] = [],\n dateTimeOptions?: ConstructorParameters<typeof DateTimeColumnFormatter>[1],\n decimalFormatOptions?: ConstructorParameters<\n typeof DecimalColumnFormatter\n >[1],\n integerFormatOptions?: ConstructorParameters<\n typeof IntegerColumnFormatter\n >[1],\n truncateNumbersWithPound = false\n ) {\n // Formatting order:\n // - columnFormatMap[type][name]\n // - typeFormatterMap[type]\n // - defaultColumnFormatter\n\n this.defaultColumnFormatter = new DefaultColumnFormatter();\n\n // Default formatters by data type\n this.typeFormatterMap = new Map<DataType, TableColumnFormatter>([\n [TableUtils.dataType.BOOLEAN, new BooleanColumnFormatter()],\n [TableUtils.dataType.CHAR, new CharColumnFormatter()],\n [\n TableUtils.dataType.DATETIME,\n new DateTimeColumnFormatter(dh, dateTimeOptions),\n ],\n [\n TableUtils.dataType.DECIMAL,\n new DecimalColumnFormatter(dh, decimalFormatOptions),\n ],\n [\n TableUtils.dataType.INT,\n new IntegerColumnFormatter(dh, integerFormatOptions),\n ],\n [TableUtils.dataType.STRING, new StringColumnFormatter()],\n ]);\n\n // Formats indexed by data type and column name\n this.columnFormatMap = Formatter.makeColumnFormatMap(columnFormattingRules);\n this.truncateNumbersWithPound = truncateNumbersWithPound;\n }\n\n defaultColumnFormatter: TableColumnFormatter;\n\n typeFormatterMap: Map<DataType, TableColumnFormatter>;\n\n columnFormatMap: Map<DataType, Map<string, TableColumnFormat>>;\n\n truncateNumbersWithPound: boolean;\n\n /**\n * Gets columnFormatMap indexed by name for a given column type, creates new Map entry if necessary\n * @param columnType column type\n * @param createIfNecessary create new entry if true\n * @returns Map of format strings indexed by column name or undefined if it doesn't exist\n */\n getColumnFormatMapForType(\n columnType: string,\n createIfNecessary = false\n ): Map<string, TableColumnFormat> | undefined {\n const dataType = TableUtils.getNormalizedType(columnType);\n if (dataType === null) {\n return undefined;\n }\n\n if (createIfNecessary && !this.columnFormatMap.has(dataType)) {\n this.columnFormatMap.set(dataType, new Map());\n }\n return this.columnFormatMap.get(dataType);\n }\n\n /**\n * Gets a column format object for a given column type and name\n * @param columnType column type\n * @param columnName column name\n * @returns format object or null for Default\n */\n getColumnFormat(\n columnType: string,\n columnName: ColumnName\n ): TableColumnFormat | null {\n const columnFormatMap = this.getColumnFormatMapForType(columnType);\n return columnFormatMap?.get(columnName) ?? null;\n }\n\n getColumnTypeFormatter(columnType: string): TableColumnFormatter {\n const dataType = TableUtils.getNormalizedType(columnType);\n let columnTypeFormatter = this.defaultColumnFormatter;\n if (dataType) {\n columnTypeFormatter =\n this.typeFormatterMap.get(dataType) ?? columnTypeFormatter;\n }\n return columnTypeFormatter;\n }\n\n /**\n * Gets formatted string for a given value, column type and name\n * @param value Value to format\n * @param columnType Column type used to determine the formatting settings\n * @param columnName Column name used to determine the formatting settings\n * @param formatOverride Format object passed to the formatter in place of the format defined in columnFormatMap\n */\n getFormattedString(\n value: unknown,\n columnType: string,\n columnName = '',\n formatOverride?: Partial<TableColumnFormat>\n ): string {\n if (value == null) {\n return '';\n }\n\n const formatter = this.getColumnTypeFormatter(columnType);\n const format =\n formatOverride || this.getColumnFormat(columnType, columnName);\n\n return formatter.format(value, format ?? undefined);\n }\n\n /**\n * Gets the timeZone name\n * @returns The time zone name E.g. America/New_York\n */\n get timeZone(): string {\n const formatter = this.typeFormatterMap.get(\n TableUtils.dataType.DATETIME\n ) as DateTimeColumnFormatter;\n return formatter?.dhTimeZone?.id;\n }\n}\n\nexport default Formatter;\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"Formatter.js","names":["TableUtils","BooleanColumnFormatter","CharColumnFormatter","DateTimeColumnFormatter","DecimalColumnFormatter","DefaultColumnFormatter","IntegerColumnFormatter","StringColumnFormatter","Formatter","makeColumnFormatMap","columnFormattingRules","Map","reduce","map","next","dataType","getNormalizedType","columnType","has","set","formatMap","get","columnName","format","makeColumnFormattingRule","constructor","dh","arguments","length","undefined","dateTimeOptions","decimalFormatOptions","integerFormatOptions","truncateNumbersWithPound","_defineProperty","defaultColumnFormatter","typeFormatterMap","BOOLEAN","CHAR","DATETIME","DECIMAL","INT","STRING","columnFormatMap","getColumnFormatMapForType","createIfNecessary","getColumnFormat","_columnFormatMap$get","getColumnTypeFormatter","columnTypeFormatter","_this$typeFormatterMa","getFormattedString","value","formatOverride","formatter","timeZone","_formatter$dhTimeZone","dhTimeZone","id"],"sources":["../src/Formatter.ts"],"sourcesContent":["import type { dh as DhType } from '@deephaven/jsapi-types';\nimport TableUtils, { DataType } from './TableUtils';\nimport {\n BooleanColumnFormatter,\n CharColumnFormatter,\n DateTimeColumnFormatter,\n DecimalColumnFormatter,\n DefaultColumnFormatter,\n IntegerColumnFormatter,\n StringColumnFormatter,\n TableColumnFormat,\n TableColumnFormatter,\n} from './formatters';\n\nexport type ColumnName = string;\n\nexport interface FormattingRule {\n columnType: string;\n columnName: ColumnName;\n format: TableColumnFormat;\n}\n\nexport class Formatter {\n /**\n * Converts FormattingRule[] to Map\n * @param columnFormattingRules Array or column formatting rules\n * @returns Map of columnName-to-format Maps indexed by normalized dataType\n */\n static makeColumnFormatMap(\n columnFormattingRules: FormattingRule[]\n ): Map<DataType, Map<ColumnName, TableColumnFormat>> {\n if (columnFormattingRules == null) {\n return new Map();\n }\n return columnFormattingRules.reduce((map, next) => {\n const dataType = TableUtils.getNormalizedType(next.columnType);\n if (dataType === null) {\n return map;\n }\n\n if (!map.has(dataType)) {\n map.set(dataType, new Map());\n }\n const formatMap = map.get(dataType);\n formatMap?.set(next.columnName, next.format);\n return map;\n }, new Map<DataType, Map<ColumnName, TableColumnFormat>>());\n }\n\n /**\n * Creates a column formatting rule\n * @param columnType Normalized data type\n * @param columnName Column name\n * @param format Format object\n */\n static makeColumnFormattingRule(\n columnType: DataType,\n columnName: ColumnName,\n format: TableColumnFormat\n ): FormattingRule {\n return {\n columnType,\n columnName,\n format,\n };\n }\n\n /**\n * @param dh JSAPI instance\n * @param columnFormattingRules Optional array of column formatting rules\n * @param dateTimeOptions Optional object with DateTime configuration\n * @param decimalFormatOptions Optional object with Decimal configuration\n * @param integerFormatOptions Optional object with Integer configuration\n * @param truncateNumbersWithPound Determine if numbers should be truncated w/ repeating # instead of ellipsis at the end\n */\n constructor(\n dh: DhType,\n columnFormattingRules: FormattingRule[] = [],\n dateTimeOptions?: ConstructorParameters<typeof DateTimeColumnFormatter>[1],\n decimalFormatOptions?: ConstructorParameters<\n typeof DecimalColumnFormatter\n >[1],\n integerFormatOptions?: ConstructorParameters<\n typeof IntegerColumnFormatter\n >[1],\n truncateNumbersWithPound = false\n ) {\n // Formatting order:\n // - columnFormatMap[type][name]\n // - typeFormatterMap[type]\n // - defaultColumnFormatter\n\n this.defaultColumnFormatter = new DefaultColumnFormatter();\n\n // Default formatters by data type\n this.typeFormatterMap = new Map<DataType, TableColumnFormatter>([\n [TableUtils.dataType.BOOLEAN, new BooleanColumnFormatter()],\n [TableUtils.dataType.CHAR, new CharColumnFormatter()],\n [\n TableUtils.dataType.DATETIME,\n new DateTimeColumnFormatter(dh, dateTimeOptions),\n ],\n [\n TableUtils.dataType.DECIMAL,\n new DecimalColumnFormatter(dh, decimalFormatOptions),\n ],\n [\n TableUtils.dataType.INT,\n new IntegerColumnFormatter(dh, integerFormatOptions),\n ],\n [TableUtils.dataType.STRING, new StringColumnFormatter()],\n ]);\n\n // Formats indexed by data type and column name\n this.columnFormatMap = Formatter.makeColumnFormatMap(columnFormattingRules);\n this.truncateNumbersWithPound = truncateNumbersWithPound;\n }\n\n defaultColumnFormatter: TableColumnFormatter;\n\n typeFormatterMap: Map<DataType, TableColumnFormatter>;\n\n columnFormatMap: Map<DataType, Map<string, TableColumnFormat>>;\n\n truncateNumbersWithPound: boolean;\n\n /**\n * Gets columnFormatMap indexed by name for a given column type, creates new Map entry if necessary\n * @param columnType column type\n * @param createIfNecessary create new entry if true\n * @returns Map of format strings indexed by column name or undefined if it doesn't exist\n */\n getColumnFormatMapForType(\n columnType: string,\n createIfNecessary = false\n ): Map<string, TableColumnFormat> | undefined {\n const dataType = TableUtils.getNormalizedType(columnType);\n if (dataType === null) {\n return undefined;\n }\n\n if (createIfNecessary && !this.columnFormatMap.has(dataType)) {\n this.columnFormatMap.set(dataType, new Map());\n }\n return this.columnFormatMap.get(dataType);\n }\n\n /**\n * Gets a column format object for a given column type and name\n * @param columnType column type\n * @param columnName column name\n * @returns format object or null for Default\n */\n getColumnFormat(\n columnType: string,\n columnName: ColumnName\n ): TableColumnFormat | null {\n const columnFormatMap = this.getColumnFormatMapForType(columnType);\n return columnFormatMap?.get(columnName) ?? null;\n }\n\n getColumnTypeFormatter(columnType: string): TableColumnFormatter {\n const dataType = TableUtils.getNormalizedType(columnType);\n let columnTypeFormatter = this.defaultColumnFormatter;\n if (dataType) {\n columnTypeFormatter =\n this.typeFormatterMap.get(dataType) ?? columnTypeFormatter;\n }\n return columnTypeFormatter;\n }\n\n /**\n * Gets formatted string for a given value, column type and name\n * @param value Value to format\n * @param columnType Column type used to determine the formatting settings\n * @param columnName Column name used to determine the formatting settings\n * @param formatOverride Format object passed to the formatter in place of the format defined in columnFormatMap\n */\n getFormattedString(\n value: unknown,\n columnType: string,\n columnName = '',\n formatOverride?: Partial<TableColumnFormat>\n ): string {\n if (value == null) {\n return '';\n }\n\n const formatter = this.getColumnTypeFormatter(columnType);\n const format =\n formatOverride || this.getColumnFormat(columnType, columnName);\n\n return formatter.format(value, format ?? undefined);\n }\n\n /**\n * Gets the timeZone name\n * @returns The time zone name E.g. America/New_York\n */\n get timeZone(): string {\n const formatter = this.typeFormatterMap.get(\n TableUtils.dataType.DATETIME\n ) as DateTimeColumnFormatter;\n return formatter?.dhTimeZone?.id;\n }\n}\n\nexport default Formatter;\n"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"FormatterUtils.js","names":["TableColumnFormatter","getColumnFormats","settings","formatter","undefined","getDateTimeFormatterOptions","timeZone","defaultDateTimeFormatString","defaultDateTimeFormat","showTimeZone","showTSeparator","isCustomColumnFormatDefined","columnName","columnType","columnFormat","getColumnFormat","type","TYPE_CONTEXT_PRESET","TYPE_CONTEXT_CUSTOM"],"sources":["../src/FormatterUtils.ts"],"sourcesContent":["import type { FormattingRule } from './Formatter';\nimport Formatter from './Formatter';\nimport { DateTimeColumnFormatter, TableColumnFormatter } from './formatters';\nimport { ColumnFormatSettings, DateTimeFormatSettings } from './Settings';\n\nexport function getColumnFormats(\n settings?: ColumnFormatSettings\n): FormattingRule[] | undefined {\n if (settings && settings.formatter) {\n const { formatter } = settings;\n return formatter;\n }\n return undefined;\n}\n\nexport function getDateTimeFormatterOptions(\n settings?: DateTimeFormatSettings | null\n): ConstructorParameters<typeof DateTimeColumnFormatter>[1] {\n return {\n timeZone: settings?.timeZone,\n defaultDateTimeFormatString: settings?.defaultDateTimeFormat,\n showTimeZone: settings?.showTimeZone,\n showTSeparator: settings?.showTSeparator,\n };\n}\n\n/**\n * Check if the formatter has a custom format defined for the column name and type\n * @param formatter Formatter to check\n * @param columnName Column name\n * @param columnType Column type\n * @returns True, if a custom format is defined\n */\nexport function isCustomColumnFormatDefined(\n formatter: Formatter,\n columnName: string,\n columnType: string\n): boolean {\n const columnFormat = formatter.getColumnFormat(columnType, columnName);\n return (\n columnFormat != null &&\n (columnFormat.type === TableColumnFormatter.TYPE_CONTEXT_PRESET ||\n columnFormat.type === TableColumnFormatter.TYPE_CONTEXT_CUSTOM)\n );\n}\n\nexport default {\n getColumnFormats,\n getDateTimeFormatterOptions,\n isCustomColumnFormatDefined,\n};\n"],"mappings":"SAEkCA,oBAAoB;AAGtD,OAAO,SAASC,
|
|
1
|
+
{"version":3,"file":"FormatterUtils.js","names":["TableColumnFormatter","getColumnFormats","settings","formatter","undefined","getDateTimeFormatterOptions","timeZone","defaultDateTimeFormatString","defaultDateTimeFormat","showTimeZone","showTSeparator","isCustomColumnFormatDefined","columnName","columnType","columnFormat","getColumnFormat","type","TYPE_CONTEXT_PRESET","TYPE_CONTEXT_CUSTOM"],"sources":["../src/FormatterUtils.ts"],"sourcesContent":["import type { FormattingRule } from './Formatter';\nimport Formatter from './Formatter';\nimport { DateTimeColumnFormatter, TableColumnFormatter } from './formatters';\nimport { ColumnFormatSettings, DateTimeFormatSettings } from './Settings';\n\nexport function getColumnFormats(\n settings?: ColumnFormatSettings\n): FormattingRule[] | undefined {\n if (settings && settings.formatter) {\n const { formatter } = settings;\n return formatter;\n }\n return undefined;\n}\n\nexport function getDateTimeFormatterOptions(\n settings?: DateTimeFormatSettings | null\n): ConstructorParameters<typeof DateTimeColumnFormatter>[1] {\n return {\n timeZone: settings?.timeZone,\n defaultDateTimeFormatString: settings?.defaultDateTimeFormat,\n showTimeZone: settings?.showTimeZone,\n showTSeparator: settings?.showTSeparator,\n };\n}\n\n/**\n * Check if the formatter has a custom format defined for the column name and type\n * @param formatter Formatter to check\n * @param columnName Column name\n * @param columnType Column type\n * @returns True, if a custom format is defined\n */\nexport function isCustomColumnFormatDefined(\n formatter: Formatter,\n columnName: string,\n columnType: string\n): boolean {\n const columnFormat = formatter.getColumnFormat(columnType, columnName);\n return (\n columnFormat != null &&\n (columnFormat.type === TableColumnFormatter.TYPE_CONTEXT_PRESET ||\n columnFormat.type === TableColumnFormatter.TYPE_CONTEXT_CUSTOM)\n );\n}\n\nexport default {\n getColumnFormats,\n getDateTimeFormatterOptions,\n isCustomColumnFormatDefined,\n};\n"],"mappings":"SAEkCA,oBAAoB;AAGtD,OAAO,SAASC,gBAAgBA,CAC9BC,QAA+B,EACD;EAC9B,IAAIA,QAAQ,IAAIA,QAAQ,CAACC,SAAS,EAAE;IAClC,IAAM;MAAEA;IAAU,CAAC,GAAGD,QAAQ;IAC9B,OAAOC,SAAS;EAClB;EACA,OAAOC,SAAS;AAClB;AAEA,OAAO,SAASC,2BAA2BA,CACzCH,QAAwC,EACkB;EAC1D,OAAO;IACLI,QAAQ,EAAEJ,QAAQ,aAARA,QAAQ,uBAARA,QAAQ,CAAEI,QAAQ;IAC5BC,2BAA2B,EAAEL,QAAQ,aAARA,QAAQ,uBAARA,QAAQ,CAAEM,qBAAqB;IAC5DC,YAAY,EAAEP,QAAQ,aAARA,QAAQ,uBAARA,QAAQ,CAAEO,YAAY;IACpCC,cAAc,EAAER,QAAQ,aAARA,QAAQ,uBAARA,QAAQ,CAAEQ;EAC5B,CAAC;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,SAASC,2BAA2BA,CACzCR,SAAoB,EACpBS,UAAkB,EAClBC,UAAkB,EACT;EACT,IAAMC,YAAY,GAAGX,SAAS,CAACY,eAAe,CAACF,UAAU,EAAED,UAAU,CAAC;EACtE,OACEE,YAAY,IAAI,IAAI,KACnBA,YAAY,CAACE,IAAI,KAAKhB,oBAAoB,CAACiB,mBAAmB,IAC7DH,YAAY,CAACE,IAAI,KAAKhB,oBAAoB,CAACkB,mBAAmB,CAAC;AAErE;AAEA,eAAe;EACbjB,gBAAgB;EAChBI,2BAA2B;EAC3BM;AACF,CAAC"}
|
package/dist/MessageUtils.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MessageUtils.js","names":["shortid","Log","TimeoutError","log","module","LOGIN_OPTIONS_REQUEST","SESSION_DETAILS_REQUEST","BROADCAST_CHANNEL_NAME","BROADCAST_LOGIN_MESSAGE","BROADCAST_LOGOUT_MESSAGE","isMessage","obj","message","id","isBroadcastLoginMessage","isBroadcastLogoutMessage","isResponse","response","makeMessage","payload","makeResponse","messageId","getWindowParent","window","opener","parent","requestParentResponse","request","timeout","Error","Promise","resolve","reject","timeoutId","listener","event","data","debug","clearTimeout","removeEventListener","addEventListener","setTimeout","postMessage"],"sources":["../src/MessageUtils.ts"],"sourcesContent":["import shortid from 'shortid';\nimport Log from '@deephaven/log';\nimport { TimeoutError } from '@deephaven/utils';\n\nconst log = Log.module('MessageUtils');\n\nexport const LOGIN_OPTIONS_REQUEST =\n 'io.deephaven.message.LoginOptions.request';\n\nexport const SESSION_DETAILS_REQUEST =\n 'io.deephaven.message.SessionDetails.request';\n\n/**\n * Use a BroadcastChannel for sending messages between tabs, such as when the user logs out.\n */\nexport const BROADCAST_CHANNEL_NAME = 'io.deephaven.broadcast';\n\n/**\n * Event emitted when the user has logged in successfully\n */\nexport const BROADCAST_LOGIN_MESSAGE = 'io.deephaven.broadcast.Login';\n\n/**\n * Event emitted when the user has logged out\n */\nexport const BROADCAST_LOGOUT_MESSAGE = 'io.deephaven.broadcast.Logout';\n\nexport interface Message<T = unknown> {\n id: string;\n message: string;\n payload?: T;\n}\n\nexport interface BroadcastLoginMessage extends Message<void> {\n message: typeof BROADCAST_LOGIN_MESSAGE;\n}\n\nexport interface BroadcastLogoutMessage extends Message<void> {\n message: typeof BROADCAST_LOGOUT_MESSAGE;\n}\n\nexport interface Response<T = unknown> {\n id: string;\n payload: T;\n}\n\nexport function isMessage(obj: unknown): obj is Message {\n const message = obj as Message;\n return (\n message != null &&\n typeof message.id === 'string' &&\n typeof message.message === 'string'\n );\n}\n\nexport function isBroadcastLoginMessage(\n obj: unknown\n): obj is BroadcastLoginMessage {\n return isMessage(obj) && obj.message === BROADCAST_LOGIN_MESSAGE;\n}\n\nexport function isBroadcastLogoutMessage(\n obj: unknown\n): obj is BroadcastLogoutMessage {\n return isMessage(obj) && obj.message === BROADCAST_LOGOUT_MESSAGE;\n}\n\nexport function isResponse(obj: unknown): obj is Response {\n const response = obj as Response;\n return response != null && typeof response.id === 'string';\n}\n\n/**\n * Make message object with optional payload\n * @param message Message string\n * @param id Unique message id\n * @param payload Payload to send\n * @returns Message\n */\nexport function makeMessage<T>(\n message: string,\n id = shortid(),\n payload?: T\n): Message<T> {\n return { message, id, payload };\n}\n\n/**\n * Make response object for given message id\n * @param messageId Id of the request message to respond to\n * @param payload Payload to respond with\n * @returns Response\n */\nexport function makeResponse<T>(messageId: string, payload: T): Response<T> {\n return { id: messageId, payload };\n}\n\nexport function getWindowParent(): Window | null {\n if (window.opener != null) {\n return window.opener;\n }\n if (window.parent != null && window.parent !== window) {\n return window.parent;\n }\n return null;\n}\n\n/**\n * Request data from the parent window and wait for response\n * @param request Request message to send to the parent window\n * @param timeout Timeout in ms\n * @returns Payload of the given type, or undefined\n */\nexport async function requestParentResponse(\n request: string,\n timeout = 30000\n): Promise<unknown> {\n const parent = getWindowParent();\n if (parent == null) {\n throw new Error('window parent is null, unable to send request.');\n }\n return new Promise((resolve, reject) => {\n let timeoutId: number;\n const id = shortid();\n const listener = (event: MessageEvent): void => {\n const { data } = event;\n if (!isResponse(data)) {\n log.debug('Ignoring non-deephaven response', data);\n return;\n }\n log.debug('Received message', data);\n if (data?.id !== id) {\n log.debug(\"Ignore message, id doesn't match\", data);\n return;\n }\n window.clearTimeout(timeoutId);\n window.removeEventListener('message', listener);\n resolve(data.payload);\n };\n window.addEventListener('message', listener);\n timeoutId = window.setTimeout(() => {\n window.removeEventListener('message', listener);\n reject(new TimeoutError('Request timed out'));\n }, timeout);\n parent.postMessage(makeMessage(request, id), '*');\n });\n}\n"],"mappings":";;AAAA,OAAOA,OAAO,MAAM,SAAS;AAC7B,OAAOC,GAAG,MAAM,gBAAgB;AAChC,SAASC,YAAY,QAAQ,kBAAkB;AAE/C,IAAMC,GAAG,GAAGF,GAAG,CAACG,MAAM,CAAC,cAAc,CAAC;AAEtC,OAAO,IAAMC,qBAAqB,GAChC,2CAA2C;AAE7C,OAAO,IAAMC,uBAAuB,GAClC,6CAA6C;;AAE/C;AACA;AACA;AACA,OAAO,IAAMC,sBAAsB,GAAG,wBAAwB;;AAE9D;AACA;AACA;AACA,OAAO,IAAMC,uBAAuB,GAAG,8BAA8B;;AAErE;AACA;AACA;AACA,OAAO,IAAMC,wBAAwB,GAAG,+BAA+B;AAqBvE,OAAO,SAASC,
|
|
1
|
+
{"version":3,"file":"MessageUtils.js","names":["shortid","Log","TimeoutError","log","module","LOGIN_OPTIONS_REQUEST","SESSION_DETAILS_REQUEST","BROADCAST_CHANNEL_NAME","BROADCAST_LOGIN_MESSAGE","BROADCAST_LOGOUT_MESSAGE","isMessage","obj","message","id","isBroadcastLoginMessage","isBroadcastLogoutMessage","isResponse","response","makeMessage","arguments","length","undefined","payload","makeResponse","messageId","getWindowParent","window","opener","parent","requestParentResponse","_x","_requestParentResponse","apply","_asyncToGenerator","request","timeout","Error","Promise","resolve","reject","timeoutId","listener","event","data","debug","clearTimeout","removeEventListener","addEventListener","setTimeout","postMessage"],"sources":["../src/MessageUtils.ts"],"sourcesContent":["import shortid from 'shortid';\nimport Log from '@deephaven/log';\nimport { TimeoutError } from '@deephaven/utils';\n\nconst log = Log.module('MessageUtils');\n\nexport const LOGIN_OPTIONS_REQUEST =\n 'io.deephaven.message.LoginOptions.request';\n\nexport const SESSION_DETAILS_REQUEST =\n 'io.deephaven.message.SessionDetails.request';\n\n/**\n * Use a BroadcastChannel for sending messages between tabs, such as when the user logs out.\n */\nexport const BROADCAST_CHANNEL_NAME = 'io.deephaven.broadcast';\n\n/**\n * Event emitted when the user has logged in successfully\n */\nexport const BROADCAST_LOGIN_MESSAGE = 'io.deephaven.broadcast.Login';\n\n/**\n * Event emitted when the user has logged out\n */\nexport const BROADCAST_LOGOUT_MESSAGE = 'io.deephaven.broadcast.Logout';\n\nexport interface Message<T = unknown> {\n id: string;\n message: string;\n payload?: T;\n}\n\nexport interface BroadcastLoginMessage extends Message<void> {\n message: typeof BROADCAST_LOGIN_MESSAGE;\n}\n\nexport interface BroadcastLogoutMessage extends Message<void> {\n message: typeof BROADCAST_LOGOUT_MESSAGE;\n}\n\nexport interface Response<T = unknown> {\n id: string;\n payload: T;\n}\n\nexport function isMessage(obj: unknown): obj is Message {\n const message = obj as Message;\n return (\n message != null &&\n typeof message.id === 'string' &&\n typeof message.message === 'string'\n );\n}\n\nexport function isBroadcastLoginMessage(\n obj: unknown\n): obj is BroadcastLoginMessage {\n return isMessage(obj) && obj.message === BROADCAST_LOGIN_MESSAGE;\n}\n\nexport function isBroadcastLogoutMessage(\n obj: unknown\n): obj is BroadcastLogoutMessage {\n return isMessage(obj) && obj.message === BROADCAST_LOGOUT_MESSAGE;\n}\n\nexport function isResponse(obj: unknown): obj is Response {\n const response = obj as Response;\n return response != null && typeof response.id === 'string';\n}\n\n/**\n * Make message object with optional payload\n * @param message Message string\n * @param id Unique message id\n * @param payload Payload to send\n * @returns Message\n */\nexport function makeMessage<T>(\n message: string,\n id = shortid(),\n payload?: T\n): Message<T> {\n return { message, id, payload };\n}\n\n/**\n * Make response object for given message id\n * @param messageId Id of the request message to respond to\n * @param payload Payload to respond with\n * @returns Response\n */\nexport function makeResponse<T>(messageId: string, payload: T): Response<T> {\n return { id: messageId, payload };\n}\n\nexport function getWindowParent(): Window | null {\n if (window.opener != null) {\n return window.opener;\n }\n if (window.parent != null && window.parent !== window) {\n return window.parent;\n }\n return null;\n}\n\n/**\n * Request data from the parent window and wait for response\n * @param request Request message to send to the parent window\n * @param timeout Timeout in ms\n * @returns Payload of the given type, or undefined\n */\nexport async function requestParentResponse(\n request: string,\n timeout = 30000\n): Promise<unknown> {\n const parent = getWindowParent();\n if (parent == null) {\n throw new Error('window parent is null, unable to send request.');\n }\n return new Promise((resolve, reject) => {\n let timeoutId: number;\n const id = shortid();\n const listener = (event: MessageEvent): void => {\n const { data } = event;\n if (!isResponse(data)) {\n log.debug('Ignoring non-deephaven response', data);\n return;\n }\n log.debug('Received message', data);\n if (data?.id !== id) {\n log.debug(\"Ignore message, id doesn't match\", data);\n return;\n }\n window.clearTimeout(timeoutId);\n window.removeEventListener('message', listener);\n resolve(data.payload);\n };\n window.addEventListener('message', listener);\n timeoutId = window.setTimeout(() => {\n window.removeEventListener('message', listener);\n reject(new TimeoutError('Request timed out'));\n }, timeout);\n parent.postMessage(makeMessage(request, id), '*');\n });\n}\n"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"NoConsolesError.js","names":["NoConsolesError","Error","isNoConsolesError","error"],"sources":["../src/NoConsolesError.ts"],"sourcesContent":["export class NoConsolesError extends Error {\n isNoConsolesError = true;\n}\n\nexport function isNoConsolesError(error: unknown): error is NoConsolesError {\n return (error as NoConsolesError).isNoConsolesError;\n}\n\nexport default NoConsolesError;\n"],"mappings":";;;AAAA,OAAO,MAAMA,eAAe,SAASC,KAAK,CAAC;
|
|
1
|
+
{"version":3,"file":"NoConsolesError.js","names":["NoConsolesError","Error","constructor","arguments","_defineProperty","isNoConsolesError","error"],"sources":["../src/NoConsolesError.ts"],"sourcesContent":["export class NoConsolesError extends Error {\n isNoConsolesError = true;\n}\n\nexport function isNoConsolesError(error: unknown): error is NoConsolesError {\n return (error as NoConsolesError).isNoConsolesError;\n}\n\nexport default NoConsolesError;\n"],"mappings":";;;AAAA,OAAO,MAAMA,eAAe,SAASC,KAAK,CAAC;EAAAC,YAAA;IAAA,SAAAC,SAAA;IAAAC,eAAA,4BACrB,IAAI;EAAA;AAC1B;AAEA,OAAO,SAASC,iBAAiBA,CAACC,KAAc,EAA4B;EAC1E,OAAQA,KAAK,CAAqBD,iBAAiB;AACrD;AAEA,eAAeL,eAAe"}
|
package/dist/SessionUtils.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SessionUtils.js","names":["Log","shortid","requestParentResponse","SESSION_DETAILS_REQUEST","NoConsolesError","isNoConsolesError","log","module","createConnection","dh","websocketUrl","info","IdeConnection","createSessionWrapper","connection","details","types","getConsoleTypes","length","type","session","startSession","config","id","generate","createCoreClient","options","CoreClient","isSessionDetails","obj","requestParentSessionDetails","response","Error","getSessionDetails","searchParams","URLSearchParams","window","location","search","get","loadSessionWrapper","sessionDetails","sessionWrapper","e"],"sources":["../src/SessionUtils.ts"],"sourcesContent":["import type {\n ConnectOptions,\n CoreClient,\n dh as DhType,\n IdeConnection,\n IdeSession,\n} from '@deephaven/jsapi-types';\nimport Log from '@deephaven/log';\nimport shortid from 'shortid';\nimport { requestParentResponse, SESSION_DETAILS_REQUEST } from './MessageUtils';\nimport NoConsolesError, { isNoConsolesError } from './NoConsolesError';\n\nconst log = Log.module('SessionUtils');\n\nexport interface SessionConfig {\n type: string;\n id: string;\n}\n\nexport interface SessionDetails {\n workerName?: string;\n processInfoId?: string;\n}\n\nexport interface SessionWrapper {\n session: IdeSession;\n connection: IdeConnection;\n config: SessionConfig;\n details?: SessionDetails;\n dh: DhType;\n}\n\n/**\n * @returns New connection to the server\n */\nexport function createConnection(\n dh: DhType,\n websocketUrl: string\n): IdeConnection {\n log.info(`Starting connection to '${websocketUrl}'...`);\n\n return new dh.IdeConnection(websocketUrl);\n}\n\n/**\n * Create a new session using the default URL\n * @returns A session and config that is ready to use\n */\nexport async function createSessionWrapper(\n dh: DhType,\n connection: IdeConnection,\n details: SessionDetails\n): Promise<SessionWrapper> {\n log.info('Getting console types...');\n\n const types = await connection.getConsoleTypes();\n\n if (types.length === 0) {\n throw new NoConsolesError('No console types available');\n }\n\n log.info('Available types:', types);\n\n const type = types[0];\n\n log.info('Starting session with type', type);\n\n const session = await connection.startSession(type);\n\n const config = { type, id: shortid.generate() };\n\n log.info('Console session established', config);\n\n return {\n session,\n config,\n connection,\n details,\n dh,\n };\n}\n\nexport function createCoreClient(\n dh: DhType,\n websocketUrl: string,\n options?: ConnectOptions\n): CoreClient {\n log.info('createCoreClient', websocketUrl);\n\n return new dh.CoreClient(websocketUrl, options);\n}\n\nfunction isSessionDetails(obj: unknown): obj is SessionDetails {\n return obj != null && typeof obj === 'object';\n}\n\nasync function requestParentSessionDetails(): Promise<SessionDetails> {\n const response = await requestParentResponse(SESSION_DETAILS_REQUEST);\n if (!isSessionDetails(response)) {\n throw new Error(`Unexpected session details response: ${response}`);\n }\n return response;\n}\n\nexport async function getSessionDetails(): Promise<SessionDetails> {\n const searchParams = new URLSearchParams(window.location.search);\n switch (searchParams.get('authProvider')) {\n case 'parent':\n return requestParentSessionDetails();\n }\n return {};\n}\n\nexport async function loadSessionWrapper(\n dh: DhType,\n connection: IdeConnection,\n sessionDetails: SessionDetails\n): Promise<SessionWrapper | undefined> {\n let sessionWrapper: SessionWrapper | undefined;\n try {\n sessionWrapper = await createSessionWrapper(dh, connection, sessionDetails);\n } catch (e) {\n // Consoles may be disabled on the server, but we should still be able to start up and open existing objects\n if (!isNoConsolesError(e)) {\n throw e;\n }\n }\n return sessionWrapper;\n}\n"],"mappings":";;AAOA,OAAOA,GAAG,MAAM,gBAAgB;AAChC,OAAOC,OAAO,MAAM,SAAS;AAAC,SACrBC,qBAAqB,EAAEC,uBAAuB;AAAA,OAChDC,eAAe,IAAIC,iBAAiB;AAE3C,IAAMC,GAAG,GAAGN,GAAG,CAACO,MAAM,CAAC,cAAc,CAAC;AAoBtC;AACA;AACA;AACA,OAAO,SAASC,
|
|
1
|
+
{"version":3,"file":"SessionUtils.js","names":["Log","shortid","requestParentResponse","SESSION_DETAILS_REQUEST","NoConsolesError","isNoConsolesError","log","module","createConnection","dh","websocketUrl","info","concat","IdeConnection","createSessionWrapper","_x","_x2","_x3","_createSessionWrapper","apply","arguments","_asyncToGenerator","connection","details","types","getConsoleTypes","length","type","session","startSession","config","id","generate","createCoreClient","options","CoreClient","isSessionDetails","obj","requestParentSessionDetails","_requestParentSessionDetails","response","Error","getSessionDetails","_getSessionDetails","searchParams","URLSearchParams","window","location","search","get","loadSessionWrapper","_x4","_x5","_x6","_loadSessionWrapper","sessionDetails","sessionWrapper","e"],"sources":["../src/SessionUtils.ts"],"sourcesContent":["import type {\n ConnectOptions,\n CoreClient,\n dh as DhType,\n IdeConnection,\n IdeSession,\n} from '@deephaven/jsapi-types';\nimport Log from '@deephaven/log';\nimport shortid from 'shortid';\nimport { requestParentResponse, SESSION_DETAILS_REQUEST } from './MessageUtils';\nimport NoConsolesError, { isNoConsolesError } from './NoConsolesError';\n\nconst log = Log.module('SessionUtils');\n\nexport interface SessionConfig {\n type: string;\n id: string;\n}\n\nexport interface SessionDetails {\n workerName?: string;\n processInfoId?: string;\n}\n\nexport interface SessionWrapper {\n session: IdeSession;\n connection: IdeConnection;\n config: SessionConfig;\n details?: SessionDetails;\n dh: DhType;\n}\n\n/**\n * @returns New connection to the server\n */\nexport function createConnection(\n dh: DhType,\n websocketUrl: string\n): IdeConnection {\n log.info(`Starting connection to '${websocketUrl}'...`);\n\n return new dh.IdeConnection(websocketUrl);\n}\n\n/**\n * Create a new session using the default URL\n * @returns A session and config that is ready to use\n */\nexport async function createSessionWrapper(\n dh: DhType,\n connection: IdeConnection,\n details: SessionDetails\n): Promise<SessionWrapper> {\n log.info('Getting console types...');\n\n const types = await connection.getConsoleTypes();\n\n if (types.length === 0) {\n throw new NoConsolesError('No console types available');\n }\n\n log.info('Available types:', types);\n\n const type = types[0];\n\n log.info('Starting session with type', type);\n\n const session = await connection.startSession(type);\n\n const config = { type, id: shortid.generate() };\n\n log.info('Console session established', config);\n\n return {\n session,\n config,\n connection,\n details,\n dh,\n };\n}\n\nexport function createCoreClient(\n dh: DhType,\n websocketUrl: string,\n options?: ConnectOptions\n): CoreClient {\n log.info('createCoreClient', websocketUrl);\n\n return new dh.CoreClient(websocketUrl, options);\n}\n\nfunction isSessionDetails(obj: unknown): obj is SessionDetails {\n return obj != null && typeof obj === 'object';\n}\n\nasync function requestParentSessionDetails(): Promise<SessionDetails> {\n const response = await requestParentResponse(SESSION_DETAILS_REQUEST);\n if (!isSessionDetails(response)) {\n throw new Error(`Unexpected session details response: ${response}`);\n }\n return response;\n}\n\nexport async function getSessionDetails(): Promise<SessionDetails> {\n const searchParams = new URLSearchParams(window.location.search);\n switch (searchParams.get('authProvider')) {\n case 'parent':\n return requestParentSessionDetails();\n }\n return {};\n}\n\nexport async function loadSessionWrapper(\n dh: DhType,\n connection: IdeConnection,\n sessionDetails: SessionDetails\n): Promise<SessionWrapper | undefined> {\n let sessionWrapper: SessionWrapper | undefined;\n try {\n sessionWrapper = await createSessionWrapper(dh, connection, sessionDetails);\n } catch (e) {\n // Consoles may be disabled on the server, but we should still be able to start up and open existing objects\n if (!isNoConsolesError(e)) {\n throw e;\n }\n }\n return sessionWrapper;\n}\n"],"mappings":"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"}
|
package/dist/TableUtils.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TableUtils.js","names":["Type","FilterType","Operator","FilterOperator","Log","bindAllMethods","PromiseUtils","removeNullAndUndefined","TextUtils","TimeoutError","DateUtils","createValueFilter","getSize","log","module","TableUtils","copyTableAndApplyFilters","maybeTable","derivedTable","copy","filterFactories","applyFilter","map","f","getSortIndex","sort","columnName","i","length","s","column","name","getSortForColumn","tableSort","sortIndex","getFilterText","filter","toString","getFilterTypes","columnType","isBooleanType","isTrue","isFalse","isNull","isCharType","isNumberType","isDateType","eq","notEq","greaterThan","greaterThanOrEqualTo","lessThan","lessThanOrEqualTo","isTextType","eqIgnoreCase","notEqIgnoreCase","contains","notContains","startsWith","endsWith","getNextSort","columns","sorts","columnIndex","asc","direction","sortDirection","ascending","desc","makeColumnSort","isAbs","none","descending","abs","toggleSortForColumn","addToExisting","newSort","setSortForColumn","sortColumn","modelColumn","concat","reverse","splice","push","getNormalizedType","dataType","BOOLEAN","CHAR","STRING","DATETIME","DECIMAL","INT","UNKNOWN","isLongType","isIntegerType","isDecimalType","isBigDecimalType","isBigIntegerType","isStringType","getBaseType","split","isCompatibleType","type1","type2","quoteValue","value","charAt","isRangeOperation","operation","makeRangeFilterWithOperation","makeCancelableTablePromise","table","makeCancelable","resolved","close","makeCancelableTableEventPromise","eventName","timeout","matcher","eventCleanup","timeoutId","isPending","wrappedPromise","Promise","resolve","reject","setTimeout","addEventListener","event","debug2","clearTimeout","cancel","removeCommas","replace","makeBooleanValue","text","allowEmpty","toLowerCase","Error","makeNumberValue","cleanText","trim","Number","POSITIVE_INFINITY","NEGATIVE_INFINITY","numberText","NUMBER_REGEX","test","parseFloat","getFilterOperatorString","isTreeTable","expand","undefined","collapse","sortColumns","isAscending","a","b","aName","toUpperCase","bName","constructor","dh","createDistinctSortedColumnTable","sourceTable","filterConditionFactories","findColumn","distinctTable","selectDistinct","distinctAscColSort","applySort","doesColumnValueExist","columnNames","isCaseSensitive","filterConditionFactory","tableCopy","size","makeQuickFilter","timeZone","orComponents","orFilter","orComponent","andComponents","andFilter","j","andComponent","makeQuickFilterFromComponent","and","or","type","makeQuickNumberFilter","makeQuickBooleanFilter","makeQuickDateFilter","makeQuickCharFilter","makeQuickTextFilter","columnFilter","regex","result","exec","negativeSign","abnormalValue","overflow","FilterCondition","invoke","FilterValue","ofNumber","not","LongWrapper","ofString","error","warn","isNaN","escapeQuickTextFilter","quickFilterText","nullRegex","substring","unescapeQuickTextFilter","prefix","suffix","notEqual","cleanValue","boolValue","e","dateText","filterOperation","makeQuickDateFilterWithOperation","startDate","endDate","parseDateRange","startValue","endValue","startFilter","endFilter","filterValue","makeAdvancedFilter","options","filterItems","filterOperators","invertSelection","selectedValues","filterItem","selectedType","newFilter","makeAdvancedValueFilter","filterOperator","err","selectValueFilter","makeSelectValueFilter","makeFilterValue","in","inIgnoreCase","notIn","notInIgnoreCase","applyNeverFilter","APPLY_TABLE_CHANGE_TIMEOUT_MS","filters","makeNeverFilter","applyCustomColumns","executeAndWaitForEvent","t","Table","EVENT_CUSTOMCOLUMNSCHANGED","EVENT_FILTERCHANGED","EVENT_SORTCHANGED","ofBoolean","DateWrapper","ofJsDate","Date","eqFilter","notEqFilter","makeFilterRawValue","rawValue","makeValue","date","values","isNullSelected","String","fromCharCode","Boolean","Object","freeze","NONE","PRE_SORT","POST_SORT","eventType","eventPromise"],"sources":["../src/TableUtils.ts"],"sourcesContent":["import {\n Type as FilterType,\n Operator as FilterOperator,\n TypeValue as FilterTypeValue,\n OperatorValue as FilterOperatorValue,\n} from '@deephaven/filters';\nimport Log from '@deephaven/log';\nimport type {\n Column,\n CustomColumn,\n dh as DhType,\n FilterCondition,\n FilterValue,\n LongWrapper,\n RemoverFn,\n Sort,\n Table,\n TreeTable,\n} from '@deephaven/jsapi-types';\nimport {\n bindAllMethods,\n CancelablePromise,\n PromiseUtils,\n removeNullAndUndefined,\n TextUtils,\n TimeoutError,\n} from '@deephaven/utils';\nimport DateUtils from './DateUtils';\nimport { ColumnName } from './Formatter';\nimport { createValueFilter, FilterConditionFactory } from './FilterUtils';\nimport { getSize } from './ViewportDataUtils';\n\nconst log = Log.module('TableUtils');\n\ntype Values<T> = T[keyof T];\nexport type DataType = Values<typeof TableUtils.dataType>;\nexport type SortDirection = Values<typeof TableUtils.sortDirection>;\nexport type ReverseType = Values<typeof TableUtils.REVERSE_TYPE>;\nexport type AdvancedFilterItemType = {\n selectedType: FilterTypeValue;\n value: string;\n};\n\nexport interface FilterItem {\n selectedType: FilterTypeValue;\n value: string;\n}\n\nexport type AdvancedFilterOptions = {\n filterItems: FilterItem[];\n filterOperators: FilterOperatorValue[];\n invertSelection: boolean;\n selectedValues: unknown[];\n};\n\nexport type RowDataMapValue = {\n type: string;\n text: string;\n value: unknown;\n isExpandable: boolean;\n isGrouped: boolean;\n visibleIndex: number;\n};\n\nexport type RowDataMap = Record<ColumnName, RowDataMapValue>;\n\n/** Utility class to provide some functions for working with tables */\nexport class TableUtils {\n static dataType = {\n BOOLEAN: 'boolean',\n CHAR: 'char',\n DATETIME: 'datetime',\n DECIMAL: 'decimal',\n INT: 'int',\n STRING: 'string',\n UNKNOWN: 'unknown',\n } as const;\n\n static sortDirection = {\n ascending: 'ASC',\n descending: 'DESC',\n reverse: 'REVERSE',\n none: null,\n } as const;\n\n static APPLY_TABLE_CHANGE_TIMEOUT_MS = 30000;\n\n static REVERSE_TYPE = Object.freeze({\n NONE: 'none',\n PRE_SORT: 'pre-sort',\n POST_SORT: 'post-sort',\n } as const);\n\n // Regex looking for a negative or positive integer or decimal number\n static NUMBER_REGEX = /^-?\\d+(\\.\\d+)?$/;\n\n /**\n * Copy a given table and apply filters.\n * @param maybeTable Table to copy and apply filters to\n * @param filterFactories Filter condition factories to apply\n * @returns A derived, filtered table\n */\n static async copyTableAndApplyFilters<\n T extends Table | null | undefined,\n R extends T extends Table ? T : null,\n >(maybeTable: T, ...filterFactories: FilterConditionFactory[]): Promise<R> {\n if (maybeTable == null) {\n return null as R;\n }\n\n const derivedTable = await maybeTable.copy();\n\n derivedTable.applyFilter(\n removeNullAndUndefined(...filterFactories.map(f => f(derivedTable)))\n );\n\n return derivedTable as R;\n }\n\n /**\n * Executes a callback on a given table and returns a Promise that will resolve\n * the next time a particular event type fires on the table.\n * @param exec Callback function to execute.\n * @param table Table that gets passed to the `exec` function and that is\n * subscribed to for a given `eventType`.\n * @param eventType The event type to listen for.\n * @param timeout If the event doesn't fire within the timeout, the returned\n * Promise will be rejected.\n * @returns a Promise to the original table that resolves on next `eventType`\n * event\n */\n static executeAndWaitForEvent = async <T extends Table | TreeTable>(\n exec: (maybeTable: T | null | undefined) => void,\n table: T | null | undefined,\n eventType: string,\n timeout = TableUtils.APPLY_TABLE_CHANGE_TIMEOUT_MS\n ): Promise<T | null> => {\n if (table == null) {\n return null;\n }\n\n const eventPromise = TableUtils.makeCancelableTableEventPromise(\n table,\n eventType,\n timeout\n );\n\n exec(table);\n\n await eventPromise;\n\n return table;\n };\n\n static getSortIndex(\n sort: readonly Sort[],\n columnName: ColumnName\n ): number | null {\n for (let i = 0; i < sort.length; i += 1) {\n const s = sort[i];\n if (s.column?.name === columnName) {\n return i;\n }\n }\n\n return null;\n }\n\n /**\n * @param tableSort The sorts from the table to get the sort from\n * @param columnName The name of the column to get the sort for\n * @returns The sort for the column, or null if it's not sorted\n */\n static getSortForColumn(\n tableSort: readonly Sort[],\n columnName: ColumnName\n ): Sort | null {\n const sortIndex = TableUtils.getSortIndex(tableSort, columnName);\n if (sortIndex != null) {\n return tableSort[sortIndex];\n }\n return null;\n }\n\n static getFilterText(filter?: FilterCondition | null): string | null {\n if (filter) {\n return filter.toString();\n }\n return null;\n }\n\n /** Return the valid filter types for the column */\n static getFilterTypes(columnType: string): FilterTypeValue[] {\n if (TableUtils.isBooleanType(columnType)) {\n return [FilterType.isTrue, FilterType.isFalse, FilterType.isNull];\n }\n if (\n TableUtils.isCharType(columnType) ||\n TableUtils.isNumberType(columnType) ||\n TableUtils.isDateType(columnType)\n ) {\n return [\n FilterType.eq,\n FilterType.notEq,\n FilterType.greaterThan,\n FilterType.greaterThanOrEqualTo,\n FilterType.lessThan,\n FilterType.lessThanOrEqualTo,\n ];\n }\n if (TableUtils.isTextType(columnType)) {\n return [\n FilterType.eq,\n FilterType.eqIgnoreCase,\n FilterType.notEq,\n FilterType.notEqIgnoreCase,\n FilterType.contains,\n FilterType.notContains,\n FilterType.startsWith,\n FilterType.endsWith,\n ];\n }\n return [];\n }\n\n static getNextSort(\n columns: readonly Column[],\n sorts: readonly Sort[],\n columnIndex: number\n ): Sort | null {\n if (columnIndex < 0 || columnIndex >= columns.length) {\n return null;\n }\n\n const sort = TableUtils.getSortForColumn(sorts, columns[columnIndex].name);\n if (sort === null) {\n return columns[columnIndex].sort().asc();\n }\n if (sort.direction === TableUtils.sortDirection.ascending) {\n return sort.desc();\n }\n return null;\n }\n\n static makeColumnSort(\n columns: readonly Column[],\n columnIndex: number,\n direction: SortDirection,\n isAbs: boolean\n ): Sort | null {\n if (columnIndex < 0 || columnIndex >= columns.length) {\n return null;\n }\n\n if (direction === TableUtils.sortDirection.none) {\n return null;\n }\n\n let sort = columns[columnIndex].sort();\n\n switch (direction) {\n case TableUtils.sortDirection.ascending:\n sort = sort.asc();\n break;\n case TableUtils.sortDirection.descending:\n sort = sort.desc();\n break;\n default:\n break;\n }\n if (isAbs) {\n sort = sort.abs();\n }\n return sort;\n }\n\n /**\n * Toggles the sort for the specified column\n * @param sorts The current sorts from IrisGrid.state\n * @param columns The columns to apply the sort to\n * @param columnIndex The column index to apply the sort to\n * @param addToExisting Add this sort to the existing sort\n */\n static toggleSortForColumn(\n sorts: readonly Sort[],\n columns: readonly Column[],\n columnIndex: number,\n addToExisting = false\n ): Sort[] {\n if (columnIndex < 0 || columnIndex >= columns.length) {\n return [];\n }\n\n const newSort = TableUtils.getNextSort(columns, sorts, columnIndex);\n\n return TableUtils.setSortForColumn(\n sorts,\n columns[columnIndex].name,\n newSort,\n addToExisting\n );\n }\n\n static sortColumn(\n sorts: readonly Sort[],\n columns: readonly Column[],\n modelColumn: number,\n direction: SortDirection,\n isAbs: boolean,\n addToExisting: boolean\n ): Sort[] {\n if (modelColumn < 0 || modelColumn >= columns.length) {\n return [];\n }\n\n const newSort = TableUtils.makeColumnSort(\n columns,\n modelColumn,\n direction,\n isAbs\n );\n\n return TableUtils.setSortForColumn(\n sorts,\n columns[modelColumn].name,\n newSort,\n addToExisting\n );\n }\n\n /**\n * Sets the sort for the given column *and* removes any reverses\n * @param tableSort The current sorts from IrisGrid.state\n * @param columnName The column name to apply the sort to\n * @param sort The sort object to add\n * @param addToExisting Add this sort to the existing sort\n * @returns Returns the modified array of sorts - removing reverses\n */\n static setSortForColumn(\n tableSort: readonly Sort[],\n columnName: ColumnName,\n sort: Sort | null,\n addToExisting = false\n ): Sort[] {\n const sortIndex = TableUtils.getSortIndex(tableSort, columnName);\n let sorts: Sort[] = [];\n if (addToExisting) {\n sorts = sorts.concat(\n tableSort.filter(\n ({ direction }) => direction !== TableUtils.sortDirection.reverse\n )\n );\n if (sortIndex !== null) {\n sorts.splice(sortIndex, 1);\n }\n }\n\n if (sort !== null) {\n sorts.push(sort);\n }\n\n return sorts;\n }\n\n static getNormalizedType(columnType?: string | null): DataType {\n switch (columnType) {\n case 'boolean':\n case 'java.lang.Boolean':\n case TableUtils.dataType.BOOLEAN:\n return TableUtils.dataType.BOOLEAN;\n case 'char':\n case 'java.lang.Character':\n case TableUtils.dataType.CHAR:\n return TableUtils.dataType.CHAR;\n case 'java.lang.String':\n case TableUtils.dataType.STRING:\n return TableUtils.dataType.STRING;\n case 'io.deephaven.db.tables.utils.DBDateTime':\n case 'io.deephaven.time.DateTime':\n case 'com.illumon.iris.db.tables.utils.DBDateTime':\n case 'java.time.Instant':\n case 'java.time.ZonedDateTime':\n case TableUtils.dataType.DATETIME:\n return TableUtils.dataType.DATETIME;\n case 'double':\n case 'java.lang.Double':\n case 'float':\n case 'java.lang.Float':\n case 'java.math.BigDecimal':\n case TableUtils.dataType.DECIMAL:\n return TableUtils.dataType.DECIMAL;\n case 'int':\n case 'java.lang.Integer':\n case 'long':\n case 'java.lang.Long':\n case 'short':\n case 'java.lang.Short':\n case 'byte':\n case 'java.lang.Byte':\n case 'java.math.BigInteger':\n case TableUtils.dataType.INT:\n return TableUtils.dataType.INT;\n default:\n return TableUtils.dataType.UNKNOWN;\n }\n }\n\n static isLongType(columnType: string): boolean {\n switch (columnType) {\n case 'long':\n case 'java.lang.Long':\n return true;\n default:\n return false;\n }\n }\n\n static isDateType(columnType: string): boolean {\n switch (columnType) {\n case 'io.deephaven.db.tables.utils.DBDateTime':\n case 'io.deephaven.time.DateTime':\n case 'java.time.Instant':\n case 'java.time.ZonedDateTime':\n case 'com.illumon.iris.db.tables.utils.DBDateTime':\n return true;\n default:\n return false;\n }\n }\n\n static isNumberType(columnType: string): boolean {\n return (\n TableUtils.isIntegerType(columnType) ||\n TableUtils.isDecimalType(columnType)\n );\n }\n\n static isIntegerType(columnType: string): boolean {\n switch (columnType) {\n case 'int':\n case 'java.lang.Integer':\n case 'java.math.BigInteger':\n case 'long':\n case 'java.lang.Long':\n case 'short':\n case 'java.lang.Short':\n case 'byte':\n case 'java.lang.Byte':\n return true;\n default:\n return false;\n }\n }\n\n static isDecimalType(columnType: string): boolean {\n switch (columnType) {\n case 'double':\n case 'java.lang.Double':\n case 'java.math.BigDecimal':\n case 'float':\n case 'java.lang.Float':\n return true;\n default:\n return false;\n }\n }\n\n static isBigDecimalType(columnType: string): boolean {\n switch (columnType) {\n case 'java.math.BigDecimal':\n return true;\n default:\n return false;\n }\n }\n\n static isBigIntegerType(columnType: string): boolean {\n switch (columnType) {\n case 'java.math.BigInteger':\n return true;\n default:\n return false;\n }\n }\n\n static isBooleanType(columnType: string): boolean {\n switch (columnType) {\n case 'boolean':\n case 'java.lang.Boolean':\n return true;\n default:\n return false;\n }\n }\n\n static isCharType(columnType: string): boolean {\n switch (columnType) {\n case 'char':\n case 'java.lang.Character':\n return true;\n default:\n return false;\n }\n }\n\n static isStringType(columnType: string): boolean {\n switch (columnType) {\n case 'java.lang.String':\n return true;\n default:\n return false;\n }\n }\n\n static isTextType(columnType: string): boolean {\n return this.isStringType(columnType) || this.isCharType(columnType);\n }\n\n /**\n * Get base column type\n * @param columnType Column type\n * @returns Element type for array columns, original type for non-array columns\n */\n static getBaseType(columnType: string): string {\n return columnType.split('[]')[0];\n }\n\n /**\n * Check if the column types are compatible\n * @param type1 Column type to check\n * @param type2 Column type to check\n * @returns True, if types are compatible\n */\n static isCompatibleType(\n type1?: string | null,\n type2?: string | null\n ): boolean {\n return (\n TableUtils.getNormalizedType(type1) ===\n TableUtils.getNormalizedType(type2)\n );\n }\n\n /**\n * Adds quotes to a value if they're not already added\n * @param value Value to add quotes around\n */\n static quoteValue(value: string): string {\n if (\n value.length >= 2 &&\n ((value.charAt(0) === '\"' && value.charAt(value.length - 1) === '\"') ||\n (value.charAt(0) === \"'\" && value.charAt(value.length - 1) === \"'\"))\n ) {\n return value;\n }\n return `\"${value}\"`;\n }\n\n static isRangeOperation(operation: string): boolean {\n switch (operation) {\n case '<':\n case '<=':\n case '=<':\n case '>':\n case '>=':\n case '=>':\n return true;\n default:\n return false;\n }\n }\n\n /**\n * @param filter The column filter to apply the range operation to\n * @param operation The range operation to run\n * @param value The value to use for the operation\n * @returns The condition with the specified operation\n */\n static makeRangeFilterWithOperation(\n filter: FilterValue,\n operation: string,\n value: FilterValue\n ): FilterCondition | null {\n switch (operation) {\n case '=':\n return filter.eq(value);\n case '<':\n return filter.lessThan(value);\n case '<=':\n case '=<':\n return filter.lessThanOrEqualTo(value);\n case '>':\n return filter.greaterThan(value);\n case '>=':\n case '=>':\n return filter.greaterThanOrEqualTo(value);\n case '!=':\n case '!':\n return filter.notEq(value);\n default:\n return null;\n }\n }\n\n /**\n * Wraps a table promise in a cancelable promise that will close the table if the promise is cancelled.\n * Use in a component that loads a table, and call cancel when unmounting.\n * @param table The table promise to wrap\n */\n static makeCancelableTablePromise(\n table: Promise<Table> | Table\n ): CancelablePromise<Table> {\n return PromiseUtils.makeCancelable(table, resolved => {\n resolved.close();\n });\n }\n\n /**\n * Make a cancelable promise for a one-shot table event with a timeout.\n * @param table Table to listen for events on\n * @param eventName Event to listen for\n * @param timeout Event timeout in milliseconds, defaults to 0\n * @param matcher Optional function to determine if the promise can be resolved or stays pending\n * @returns Resolves with the event data\n */\n static makeCancelableTableEventPromise(\n table: Table | TreeTable,\n eventName: string,\n timeout = 0,\n matcher: ((event: CustomEvent) => boolean) | null = null\n ): CancelablePromise<CustomEvent> {\n let eventCleanup: RemoverFn;\n let timeoutId: ReturnType<typeof setTimeout>;\n let isPending = true;\n const wrappedPromise = new Promise((resolve, reject) => {\n timeoutId = setTimeout(() => {\n eventCleanup();\n isPending = false;\n reject(new TimeoutError(`Event \"${eventName}\" timed out.`));\n }, timeout);\n eventCleanup = table.addEventListener(eventName, event => {\n if (matcher != null && !matcher(event)) {\n log.debug2('Event triggered, but matcher returned false.');\n return;\n }\n log.debug2('Event triggered, resolving.');\n eventCleanup();\n clearTimeout(timeoutId);\n isPending = false;\n resolve(event);\n });\n }) as CancelablePromise<CustomEvent>;\n wrappedPromise.cancel = () => {\n if (isPending) {\n log.debug2('Pending promise cleanup.');\n eventCleanup();\n clearTimeout(timeoutId);\n isPending = false;\n return;\n }\n log.debug2('Ignoring non-pending promise cancel.');\n };\n return wrappedPromise;\n }\n\n static removeCommas(value: string): string {\n return value.replace(/[\\s|,]/g, '');\n }\n\n static makeBooleanValue(text: string, allowEmpty = false): boolean | null {\n if (text === '' && allowEmpty) {\n return null;\n }\n\n switch (text?.toLowerCase()) {\n case 'null':\n return null;\n case '0':\n case 'f':\n case 'fa':\n case 'fal':\n case 'fals':\n case 'false':\n case 'n':\n case 'no':\n return false;\n case '1':\n case 't':\n case 'tr':\n case 'tru':\n case 'true':\n case 'y':\n case 'ye':\n case 'yes':\n return true;\n default:\n throw new Error(`Invalid boolean '${text}'`);\n }\n }\n\n static makeNumberValue(text: string): number | null {\n if (text === 'null' || text === '') {\n return null;\n }\n\n const cleanText = text.toLowerCase().trim();\n if (cleanText === '∞' || cleanText === 'infinity' || cleanText === 'inf') {\n return Number.POSITIVE_INFINITY;\n }\n if (\n cleanText === '-∞' ||\n cleanText === '-infinity' ||\n cleanText === '-inf'\n ) {\n return Number.NEGATIVE_INFINITY;\n }\n\n const numberText = TableUtils.removeCommas(cleanText);\n if (TableUtils.NUMBER_REGEX.test(numberText)) {\n return parseFloat(numberText);\n }\n\n throw new Error(`Invalid number '${text}'`);\n }\n\n static getFilterOperatorString(operation: FilterTypeValue): string {\n switch (operation) {\n case FilterType.eq:\n return '=';\n case FilterType.notEq:\n return '!=';\n case FilterType.greaterThan:\n return '>';\n case FilterType.greaterThanOrEqualTo:\n return '>=';\n case FilterType.lessThan:\n return '<';\n case FilterType.lessThanOrEqualTo:\n return '<=';\n case FilterType.contains:\n return '~';\n case FilterType.notContains:\n return '!~';\n default:\n throw new Error(`Unexpected filter type ${operation}`);\n }\n }\n\n static isTreeTable(table: unknown): table is TreeTable {\n return (\n table != null &&\n (table as TreeTable).expand !== undefined &&\n (table as TreeTable).collapse !== undefined\n );\n }\n\n /**\n * Copies the provided array, sorts by column name case insensitive, and returns the sorted array.\n * @param columns The columns to sort\n * @param isAscending Whether to sort ascending\n */\n static sortColumns(columns: readonly Column[], isAscending = true): Column[] {\n return [...columns].sort((a, b) => {\n const aName = a.name.toUpperCase();\n const bName = b.name.toUpperCase();\n return TextUtils.sort(aName, bName, isAscending);\n });\n }\n\n dh: DhType;\n\n constructor(dh: DhType) {\n this.dh = dh;\n bindAllMethods(this);\n }\n\n /**\n * Create a table containing a distinct list of values for given column name and\n * applies the given sort direction.\n * @param table Source table to derive table from\n * @param columnName Column to dermine distinct values\n * @param sortDirection Direction to sort\n * @param filterConditionFactories Optional filters to apply. Note that these\n * will be applied before the `selectCall` in case we need to base the filtering\n * on columns other than the distinct value column\n */\n async createDistinctSortedColumnTable(\n table: Table | null | undefined,\n columnName: string,\n sortDirection: 'asc' | 'desc',\n ...filterConditionFactories: FilterConditionFactory[]\n ): Promise<Table | null> {\n if (table == null) {\n return null;\n }\n\n let sourceTable = table;\n\n // Applying filters before `selectDistinct` so that we still have access to\n // all columns. Also prevents a filter applied to the final table from\n // clearing this filter.\n if (filterConditionFactories.length > 0) {\n sourceTable = await table.copy();\n\n await sourceTable.applyFilter(\n removeNullAndUndefined(\n ...filterConditionFactories.map(f => f(sourceTable))\n )\n );\n }\n\n const column = sourceTable.findColumn(columnName);\n const distinctTable = await sourceTable.selectDistinct([column]);\n\n // If we copied the table, dispose the copy. Original is managed outside\n // of this function\n if (sourceTable !== table) {\n sourceTable.close();\n }\n\n const distinctAscColSort = distinctTable\n .findColumn(columnName)\n .sort()\n [sortDirection]();\n\n return this.applySort(distinctTable, [distinctAscColSort]);\n }\n\n /**\n * Check if any columns contain a given value.\n * @param table Table to search for values\n * @param columnNames Column names to search\n * @param value Value to search for\n * @param isCaseSensitive Whether the value check is case sensitive\n */\n async doesColumnValueExist(\n table: Table | null | undefined,\n columnNames: string | string[],\n value: string,\n isCaseSensitive: boolean\n ): Promise<boolean | null> {\n if (table == null) {\n return null;\n }\n\n const filterConditionFactory = createValueFilter(\n this,\n columnNames,\n value,\n isCaseSensitive ? 'eq' : 'eqIgnoreCase'\n );\n\n const tableCopy = await table.copy();\n\n await this.applyFilter(\n tableCopy,\n removeNullAndUndefined(filterConditionFactory(tableCopy))\n );\n\n const size = getSize(tableCopy);\n\n tableCopy.close();\n\n return size > 0;\n }\n\n /**\n * Create filter with the provided column and text. Handles multiple filters joined with && or ||\n * @param column The column to set the filter on\n * @param text The text string to create the filter from\n * @param timeZone The time zone to make this value in if it is a date type. E.g. America/New_York\n * @returns Returns the created filter, null if text could not be parsed\n */\n makeQuickFilter(\n column: Column,\n text: string,\n timeZone?: string\n ): FilterCondition | null {\n const orComponents = text.split('||');\n let orFilter = null;\n for (let i = 0; i < orComponents.length; i += 1) {\n const orComponent = orComponents[i];\n const andComponents = orComponent.split('&&');\n let andFilter = null;\n for (let j = 0; j < andComponents.length; j += 1) {\n const andComponent = andComponents[j].trim();\n if (andComponent.length > 0) {\n const filter = this.makeQuickFilterFromComponent(\n column,\n andComponent,\n timeZone\n );\n if (filter) {\n if (andFilter) {\n andFilter = andFilter.and(filter);\n } else {\n andFilter = filter;\n }\n } else {\n throw new Error(`Unable to parse quick filter from text ${text}`);\n }\n }\n }\n\n if (orFilter && andFilter) {\n orFilter = orFilter.or(andFilter);\n } else {\n orFilter = andFilter;\n }\n }\n\n return orFilter;\n }\n\n /**\n * Create filter with the provided column and text of one component (no multiple conditions)\n * @param column The column to set the filter on\n * @param text The text string to create the filter from\n * @param timeZone The time zone to make this filter in if it is a date type. E.g. America/New_York\n * @returns Returns the created filter, null if text could not be parsed\n */\n makeQuickFilterFromComponent(\n column: Column,\n text: string,\n timeZone?: string\n ): FilterCondition | null {\n const { type } = column;\n if (TableUtils.isNumberType(type)) {\n return this.makeQuickNumberFilter(column, text);\n }\n if (TableUtils.isBooleanType(type)) {\n return this.makeQuickBooleanFilter(column, text);\n }\n if (timeZone != null && TableUtils.isDateType(type)) {\n return this.makeQuickDateFilter(column, text, timeZone);\n }\n if (TableUtils.isCharType(type)) {\n return this.makeQuickCharFilter(column, text);\n }\n return this.makeQuickTextFilter(column, text);\n }\n\n makeQuickNumberFilter(column: Column, text: string): FilterCondition | null {\n const columnFilter = column.filter();\n const { dh } = this;\n let filter = null;\n\n const regex =\n /\\s*(>=|<=|=>|=<|>|<|!=|=|!)?(\\s*-\\s*)?(\\s*\\d*(?:,\\d{3})*(?:\\.\\d*)?\\s*)?(null|nan|infinity|inf|\\u221E)?(.*)/i;\n const result = regex.exec(text);\n\n let operation = null;\n let negativeSign = null;\n let value = null;\n let abnormalValue = null; // includes nan, null and infinity(positive & negative)\n let overflow = null;\n\n if (result !== null && result.length > 3) {\n [, operation, negativeSign, value, abnormalValue, overflow] = result;\n }\n\n if (overflow != null && overflow.trim().length > 0) {\n // Some bad characters after the number, bail out!\n return null;\n }\n\n if (operation == null) {\n operation = '=';\n }\n\n if (abnormalValue != null) {\n if (!(operation === '=' || operation === '!' || operation === '!=')) {\n // only equal and not equal operations are supported for abnormal value filter\n return null;\n }\n abnormalValue = abnormalValue.trim().toLowerCase();\n switch (abnormalValue) {\n case 'null':\n filter = columnFilter.isNull();\n break;\n case 'nan':\n filter = dh.FilterCondition.invoke('isNaN', columnFilter);\n break;\n case 'infinity':\n case 'inf':\n case '\\u221E':\n if (negativeSign != null) {\n filter = dh.FilterCondition.invoke('isInf', columnFilter).and(\n columnFilter.lessThan(dh.FilterValue.ofNumber(0))\n );\n } else {\n filter = dh.FilterCondition.invoke('isInf', columnFilter).and(\n columnFilter.greaterThan(dh.FilterValue.ofNumber(0))\n );\n }\n break;\n default:\n break;\n }\n if (filter !== null && (operation === '!' || operation === '!=')) {\n filter = filter.not();\n }\n return filter;\n }\n\n if (value == null) {\n return null;\n }\n\n value = TableUtils.removeCommas(value);\n if (TableUtils.isLongType(column.type)) {\n try {\n value = dh.FilterValue.ofNumber(\n dh.LongWrapper.ofString(`${negativeSign != null ? '-' : ''}${value}`)\n );\n } catch (error) {\n log.warn('Unable to create long filter', error);\n return null;\n }\n } else {\n value = parseFloat(value);\n if (value == null || Number.isNaN(value)) {\n return null;\n }\n\n value = dh.FilterValue.ofNumber(negativeSign != null ? 0 - value : value);\n }\n\n filter = column.filter();\n\n return TableUtils.makeRangeFilterWithOperation(filter, operation, value);\n }\n\n /**\n * Given a text string from a table, escape quick filter operators in string with \\\n * ex. =test returns \\=test, null returns \\null\n * @param string quickfilter string to escape\n * @returns escaped string\n */\n static escapeQuickTextFilter(quickFilterText: string | null): string | null {\n if (quickFilterText == null) return null;\n const regex = /^(!~|!=|~|=|!)?(.*)/;\n // starts with zero or more \\ followed by and ending with null\n const nullRegex = /^\\\\*null$/;\n const result = regex.exec(quickFilterText);\n let operation: string | null = null;\n let value: string | null = null;\n if (result !== null && result.length > 2) {\n [, operation, value] = result;\n }\n\n if (operation != null) {\n return `\\\\${operation}${value ?? ''}`;\n }\n\n if (value != null && nullRegex.test(value.toLowerCase())) {\n // adds an extra escape character to matching value\n return `\\\\${value}`;\n }\n if (value != null && value.startsWith('*')) {\n return `\\\\${value}`;\n }\n if (value != null && value.endsWith('*') && !value.endsWith('\\\\*')) {\n value = value.substring(0, value.length - 1);\n return `${value}\\\\*`;\n }\n\n return `${operation ?? ''}${value ?? ``}`;\n }\n\n /**\n * Given an escaped quick filter, unescape the operators for giving it to the js api\n * ex. \\=test returns =test, \\null returns null\n * @param string quickfilter string to escape\n * @returns escaped string\n */\n static unescapeQuickTextFilter(quickFilterText: string): string {\n const regex = /^(\\\\!~|\\\\!=|\\\\~|\\\\=|\\\\!)?(.*)/;\n // starts with zero or more \\ followed by and ending with null\n const nullRegex = /^\\\\*null$/;\n const result = regex.exec(quickFilterText);\n let operation: string | null = null;\n let value: string | null = null;\n if (result !== null && result.length > 2) {\n [, operation, value] = result;\n }\n\n if (operation != null) {\n operation = operation.replace('\\\\', '');\n }\n\n if (value != null && nullRegex.test(value.toLowerCase())) {\n // removes the first occurance of the backslash\n value = value.replace('\\\\', '');\n }\n if (operation == null && value != null && value.startsWith('\\\\*')) {\n value = value.substring(1);\n }\n if (operation == null && value != null && value.endsWith('\\\\*')) {\n value = value.substring(0, value.length - 2);\n return `${value}*`;\n }\n\n return `${operation ?? ''}${value ?? ``}`;\n }\n\n makeQuickTextFilter(column: Column, text: string): FilterCondition | null {\n const { dh } = this;\n const cleanText = `${text}`.trim();\n const regex = /^(!~|!=|~|=|!)?(.*)/;\n const result = regex.exec(cleanText);\n\n let operation = null;\n let value = null;\n if (result !== null && result.length > 2) {\n [, operation, value] = result;\n if (value != null) {\n value = value.trim();\n }\n }\n\n if (value == null) {\n return null;\n }\n\n // allow empty strings, but only for explicit equal and not equal\n if (value.length === 0 && !(operation === '=' || operation === '!=')) {\n return null;\n }\n\n // no operation is treated as an implicit equals\n if (operation == null) {\n operation = '=';\n }\n\n const filter = column.filter();\n if (value.toLowerCase() === 'null') {\n // Null is a special case!\n switch (operation) {\n case '=':\n return filter.isNull();\n case '!=':\n case '!':\n return filter.isNull().not();\n default:\n // For all other operations, treat null as a string value\n }\n }\n\n let prefix = null;\n let suffix = null;\n if (value.startsWith('*')) {\n prefix = '*';\n value = value.substring(1);\n } else if (value.endsWith('*') && !value.endsWith('\\\\*')) {\n suffix = '*';\n value = value.substring(0, value.length - 1);\n }\n\n // unescape any escaped operators to allow search for literal operators\n value = TableUtils.unescapeQuickTextFilter(value);\n\n switch (operation) {\n case '~': {\n return filter\n .isNull()\n .not()\n .and(\n filter.invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i).*\\\\Q${value}\\\\E.*`)\n )\n );\n }\n case '!~':\n return filter\n .isNull()\n .or(\n filter\n .invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i).*\\\\Q${value}\\\\E.*`)\n )\n .not()\n );\n case '!=':\n if (prefix === '*') {\n // Does not end with\n return filter\n .isNull()\n .or(\n filter\n .invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i).*\\\\Q${value}\\\\E$`)\n )\n .not()\n );\n }\n if (suffix === '*') {\n // Does not start with\n return filter\n .isNull()\n .or(\n filter\n .invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i)^\\\\Q${value}\\\\E.*`)\n )\n .not()\n );\n }\n return filter.notEqIgnoreCase(\n dh.FilterValue.ofString(value.toLowerCase())\n );\n case '=':\n if (prefix === '*') {\n // Ends with\n return filter\n .isNull()\n .not()\n .and(\n filter.invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i).*\\\\Q${value}\\\\E$`)\n )\n );\n }\n if (suffix === '*') {\n // Starts with\n return filter\n .isNull()\n .not()\n .and(\n filter.invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i)^\\\\Q${value}\\\\E.*`)\n )\n );\n }\n return filter.eqIgnoreCase(\n dh.FilterValue.ofString(value.toLowerCase())\n );\n\n default:\n break;\n }\n\n return null;\n }\n\n // eslint-disable-next-line class-methods-use-this\n makeQuickBooleanFilter(\n column: Column,\n text: string | number\n ): FilterCondition | null {\n const regex = /^(!=|=|!)?(.*)/;\n const result = regex.exec(`${text}`.trim());\n if (result === null) {\n return null;\n }\n const [, operation, value] = result;\n const notEqual = operation === '!' || operation === '!=';\n const cleanValue = value.trim().toLowerCase();\n\n let filter: FilterCondition | FilterValue = column.filter();\n\n try {\n const boolValue = TableUtils.makeBooleanValue(cleanValue);\n if (boolValue != null && boolValue) {\n filter = filter.isTrue();\n } else if (boolValue === null) {\n filter = filter.isNull();\n } else {\n filter = filter.isFalse();\n }\n\n return notEqual ? filter.not() : filter;\n } catch (e) {\n return null;\n }\n }\n\n /**\n * Builds a date filter parsed from the text string which may or may not include an operator.\n * @param column The column to build the filter from, with or without a leading operator.\n * @param text The date string text to parse.\n * @param timeZone The time zone to make this filter in if it is a date type. E.g. America/New_York\n */\n makeQuickDateFilter(\n column: Column,\n text: string,\n timeZone: string\n ): FilterCondition {\n const cleanText = text.trim();\n const regex = /\\s*(>=|<=|=>|=<|>|<|!=|!|=)?(.*)/;\n const result = regex.exec(cleanText);\n if (result == null || result.length <= 2) {\n throw new Error(`Unable to parse date filter: ${text}`);\n }\n\n let operation = null;\n let dateText = null;\n\n [, operation, dateText] = result;\n\n let filterOperation: FilterTypeValue = FilterType.eq;\n switch (operation) {\n case '<':\n filterOperation = FilterType.lessThan;\n break;\n case '<=':\n case '=<':\n filterOperation = FilterType.lessThanOrEqualTo;\n break;\n case '>':\n filterOperation = FilterType.greaterThan;\n break;\n case '>=':\n case '=>':\n filterOperation = FilterType.greaterThanOrEqualTo;\n break;\n case '!=':\n case '!':\n filterOperation = FilterType.notEq;\n break;\n case '=':\n case '==':\n default:\n filterOperation = FilterType.eq;\n break;\n }\n\n return this.makeQuickDateFilterWithOperation(\n column,\n dateText,\n filterOperation,\n timeZone\n );\n }\n\n /**\n * Builds a date filter parsed from the text string with the provided filter.\n * @param column The column to build the filter from.\n * @param text The date string text to parse, without an operator.\n * @param operation The filter operation to use.\n * @param timeZone The time zone to make this filter with. E.g. America/New_York\n */\n makeQuickDateFilterWithOperation(\n column: Column,\n text: string,\n operation: FilterTypeValue,\n timeZone: string\n ): FilterCondition {\n const { dh } = this;\n const [startDate, endDate] = DateUtils.parseDateRange(dh, text, timeZone);\n\n const startValue =\n startDate != null ? dh.FilterValue.ofNumber(startDate) : null;\n const endValue = endDate != null ? dh.FilterValue.ofNumber(endDate) : null;\n\n const filter = column.filter();\n if (startValue == null) {\n return operation === FilterType.notEq\n ? filter.isNull().not()\n : filter.isNull();\n }\n\n switch (operation) {\n case FilterType.eq: {\n if (endValue != null) {\n const startFilter = filter.greaterThanOrEqualTo(startValue);\n const endFilter = filter.lessThan(endValue);\n return startFilter.and(endFilter);\n }\n return filter.eq(startValue);\n }\n case FilterType.lessThan: {\n return filter.lessThan(startValue);\n }\n case FilterType.lessThanOrEqualTo: {\n if (endValue != null) {\n return filter.lessThan(endValue);\n }\n return filter.lessThanOrEqualTo(startValue);\n }\n case FilterType.greaterThan: {\n if (endValue != null) {\n return filter.greaterThanOrEqualTo(endValue);\n }\n return filter.greaterThan(startValue);\n }\n case FilterType.greaterThanOrEqualTo:\n return filter.greaterThanOrEqualTo(startValue);\n case FilterType.notEq: {\n if (endValue != null) {\n const startFilter = filter.lessThan(startValue);\n const endFilter = filter.greaterThanOrEqualTo(endValue);\n return startFilter.or(endFilter);\n }\n return filter.notEq(startValue);\n }\n\n default:\n throw new Error(`Invalid operator: ${operation}`);\n }\n }\n\n makeQuickCharFilter(column: Column, text: string): FilterCondition | null {\n const { dh } = this;\n const cleanText = `${text}`.trim();\n const regex = /^(>=|<=|=>|=<|>|<|!=|=|!)?(null|\".\"|'.'|.)?(.*)/;\n const result = regex.exec(cleanText);\n\n let operation = null;\n let value = null;\n let overflow = null;\n if (result !== null && result.length > 3) {\n [, operation, value, overflow] = result;\n }\n if (overflow != null && overflow.trim().length > 0) {\n // Some bad characters after the number, bail out!\n return null;\n }\n\n if (value == null || value.length === 0) {\n return null;\n }\n\n if (operation == null) {\n operation = '=';\n }\n\n const filter = column.filter();\n if (value.toLowerCase() === 'null') {\n // Null is a special case!\n switch (operation) {\n case '=':\n return filter.isNull();\n case '!=':\n case '!':\n return filter.isNull().not();\n default:\n return null;\n }\n }\n\n // We need to put quotes around range operations or else the API fails\n const filterValue = dh.FilterValue.ofString(\n TableUtils.isRangeOperation(operation)\n ? TableUtils.quoteValue(value)\n : value\n );\n return TableUtils.makeRangeFilterWithOperation(\n filter,\n operation,\n filterValue\n );\n }\n\n makeAdvancedFilter(\n column: Column,\n options: AdvancedFilterOptions,\n timeZone: string\n ): FilterCondition | null {\n const { filterItems, filterOperators, invertSelection, selectedValues } =\n options;\n let filter = null;\n for (let i = 0; i < filterItems.length; i += 1) {\n const filterItem = filterItems[i];\n const { selectedType, value } = filterItem;\n if (\n selectedType != null &&\n selectedType.length > 0 &&\n value != null &&\n value.length > 0\n ) {\n try {\n const newFilter = this.makeAdvancedValueFilter(\n column,\n selectedType,\n value,\n timeZone\n );\n if (newFilter != null) {\n if (i === 0) {\n filter = newFilter;\n } else if (filter !== null && i - 1 < filterOperators.length) {\n const filterOperator = filterOperators[i - 1];\n if (filterOperator === FilterOperator.and) {\n filter = filter.and(newFilter);\n } else if (filterOperator === FilterOperator.or) {\n filter = filter.or(newFilter);\n } else {\n log.error(\n 'Unexpected filter operator',\n filterOperator,\n newFilter\n );\n filter = null;\n break;\n }\n }\n } else {\n log.debug2('Empty filter ignored for', selectedType, value);\n }\n } catch (err) {\n log.error('Unable to create filter', err);\n filter = null;\n break;\n }\n }\n }\n\n const selectValueFilter = this.makeSelectValueFilter(\n column,\n selectedValues,\n invertSelection\n );\n if (selectValueFilter != null) {\n if (filter != null) {\n filter = filter.and(selectValueFilter);\n } else {\n filter = selectValueFilter;\n }\n }\n\n return filter;\n }\n\n makeAdvancedValueFilter(\n column: Column,\n operation: FilterTypeValue,\n value: string,\n timeZone: string\n ): FilterCondition | null {\n const { dh } = this;\n if (TableUtils.isDateType(column.type)) {\n return this.makeQuickDateFilterWithOperation(\n column,\n value,\n operation,\n timeZone\n );\n }\n\n if (\n TableUtils.isNumberType(column.type) ||\n TableUtils.isCharType(column.type)\n ) {\n return this.makeQuickFilter(\n column,\n `${TableUtils.getFilterOperatorString(operation)}${value}`\n );\n }\n\n const filterValue = this.makeFilterValue(column.type, value);\n const filter = column.filter();\n switch (operation) {\n case FilterType.eq:\n return filter.eq(filterValue);\n case FilterType.eqIgnoreCase:\n return filter.eqIgnoreCase(filterValue);\n case FilterType.notEq:\n return filter.notEq(filterValue);\n case FilterType.notEqIgnoreCase:\n return filter.notEqIgnoreCase(filterValue);\n case FilterType.greaterThan:\n return filter.greaterThan(filterValue);\n case FilterType.greaterThanOrEqualTo:\n return filter.greaterThanOrEqualTo(filterValue);\n case FilterType.lessThan:\n return filter.lessThan(filterValue);\n case FilterType.lessThanOrEqualTo:\n return filter.lessThanOrEqualTo(filterValue);\n case FilterType.isTrue:\n return filter.isTrue();\n case FilterType.isFalse:\n return filter.isFalse();\n case FilterType.isNull:\n return filter.isNull();\n case FilterType.contains:\n return filter\n .isNull()\n .not()\n .and(\n filter.invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i).*\\\\Q${value}\\\\E.*`)\n )\n );\n case FilterType.notContains:\n return filter\n .isNull()\n .or(\n filter\n .invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i).*\\\\Q${value}\\\\E.*`)\n )\n .not()\n );\n case FilterType.startsWith:\n return filter\n .isNull()\n .not()\n .and(\n filter.invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i)^\\\\Q${value}\\\\E.*`)\n )\n );\n case FilterType.endsWith:\n return filter\n .isNull()\n .not()\n .and(\n filter.invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i).*\\\\Q${value}\\\\E$`)\n )\n );\n case FilterType.in:\n case FilterType.inIgnoreCase:\n case FilterType.notIn:\n case FilterType.notInIgnoreCase:\n case FilterType.invoke:\n default:\n throw new Error(`Unexpected filter operation: ${operation}`);\n }\n }\n\n /**\n * Apply a filter to a table that won't match anything.\n * @table The table to apply the filter to\n * @columnName The name of the column to apploy the filter to\n * @param timeout Timeout before cancelling the promise that waits for the next\n * dh.Table.EVENT_FILTERCHANGED event\n * @returns a Promise to the Table that resolves after the next\n * dh.Table.EVENT_FILTERCHANGED event\n */\n async applyNeverFilter<T extends Table | TreeTable>(\n table: T | null | undefined,\n columnName: string,\n timeout = TableUtils.APPLY_TABLE_CHANGE_TIMEOUT_MS\n ): Promise<T | null> {\n if (table == null) {\n return null;\n }\n\n const column = table.findColumn(columnName);\n const filters = [this.makeNeverFilter(column)];\n\n await this.applyFilter(table, filters, timeout);\n\n return table;\n }\n\n /**\n * Apply custom columns to a given table. Return a Promise that resolves with\n * the table once the dh.Table.EVENT_CUSTOMCOLUMNSCHANGED event has fired.\n * @param table The table to apply custom columns to.\n * @param columns The list of column expressions or definitions to apply.\n * @returns A Promise that will be resolved with the given table after the\n * columns are applied.\n */\n async applyCustomColumns(\n table: Table | null | undefined,\n columns: (string | CustomColumn)[],\n timeout = TableUtils.APPLY_TABLE_CHANGE_TIMEOUT_MS\n ): Promise<Table | null> {\n const { dh } = this;\n return TableUtils.executeAndWaitForEvent(\n t => t?.applyCustomColumns(columns),\n table,\n dh.Table.EVENT_CUSTOMCOLUMNSCHANGED,\n timeout\n );\n }\n\n /**\n * Apply filters to a given table.\n * @param table Table to apply filters to\n * @param filters Filters to apply\n * @param timeout Timeout before cancelling the promise that waits for the next\n * dh.Table.EVENT_FILTERCHANGED event\n * @returns a Promise to the Table that resolves after the next\n * dh.Table.EVENT_FILTERCHANGED event\n */\n async applyFilter<T extends Table | TreeTable>(\n table: T | null | undefined,\n filters: FilterCondition[],\n timeout = TableUtils.APPLY_TABLE_CHANGE_TIMEOUT_MS\n ): Promise<T | null> {\n const { dh } = this;\n return TableUtils.executeAndWaitForEvent(\n t => t?.applyFilter(filters),\n table,\n dh.Table.EVENT_FILTERCHANGED,\n timeout\n );\n }\n\n /**\n * Apply sorts to a given Table.\n * @param table The table to apply sorts to\n * @param sorts The sorts to apply\n * @param timeout Timeout before cancelling the promise that waits for the next\n * dh.Table.EVENT_SORTCHANGED event\n * @returns a Promise to the Table that resolves after the next\n * dh.Table.EVENT_SORTCHANGED event\n */\n async applySort<T extends Table | TreeTable>(\n table: T | null | undefined,\n sorts: Sort[],\n timeout = TableUtils.APPLY_TABLE_CHANGE_TIMEOUT_MS\n ): Promise<T | null> {\n const { dh } = this;\n return TableUtils.executeAndWaitForEvent(\n t => t?.applySort(sorts),\n table,\n dh.Table.EVENT_SORTCHANGED,\n timeout\n );\n }\n\n /**\n * Create a filter condition that results in zero results for a given column\n * @param column\n */\n makeNeverFilter(column: Column): FilterCondition {\n const { dh } = this;\n let value = null;\n\n if (TableUtils.isTextType(column.type)) {\n // Use 'a' so that it can work for String or Character types\n value = dh.FilterValue.ofString('a');\n } else if (TableUtils.isBooleanType(column.type)) {\n value = dh.FilterValue.ofBoolean(true);\n } else if (TableUtils.isDateType(column.type)) {\n value = dh.FilterValue.ofNumber(dh.DateWrapper.ofJsDate(new Date()));\n } else {\n value = dh.FilterValue.ofNumber(0);\n }\n\n const eqFilter = column.filter().eq(value);\n const notEqFilter = column.filter().notEq(value);\n\n return eqFilter.and(notEqFilter);\n }\n\n /**\n * @param columnType The column type to make the filter value from.\n * @param value The value to make the filter value from.\n * @returns The FilterValue item for this column/value combination\n */\n makeFilterValue(columnType: string, value: string): FilterValue {\n const { dh } = this;\n const type = TableUtils.getBaseType(columnType);\n if (TableUtils.isTextType(type)) {\n return dh.FilterValue.ofString(value);\n }\n if (TableUtils.isLongType(type)) {\n return dh.FilterValue.ofNumber(\n dh.LongWrapper.ofString(TableUtils.removeCommas(value))\n );\n }\n\n return dh.FilterValue.ofNumber(TableUtils.removeCommas(value));\n }\n\n /**\n * Takes a value and converts it to an `dh.FilterValue`\n *\n * @param columnType The column type to make the filter value from.\n * @param value The value to actually set\n * @returns The FilterValue item for this column/value combination\n */\n makeFilterRawValue(columnType: string, rawValue: unknown): FilterValue {\n const { dh } = this;\n if (TableUtils.isTextType(columnType)) {\n return dh.FilterValue.ofString(rawValue);\n }\n\n if (TableUtils.isBooleanType(columnType)) {\n return dh.FilterValue.ofBoolean(rawValue);\n }\n\n return dh.FilterValue.ofNumber(rawValue);\n }\n\n /**\n * Converts a string value to a value appropriate for the column\n * @param columnType The column type to make the value for\n * @param text The string value to make a type for\n * @param timeZone The time zone to make this value in if it is a date type. E.g. America/New_York\n */\n makeValue(\n columnType: string,\n text: string,\n timeZone: string\n ): string | number | boolean | LongWrapper | null {\n const { dh } = this;\n if (text === 'null') {\n return null;\n }\n if (TableUtils.isTextType(columnType)) {\n return text;\n }\n if (TableUtils.isLongType(columnType)) {\n return dh.LongWrapper.ofString(TableUtils.removeCommas(text));\n }\n if (TableUtils.isBooleanType(columnType)) {\n return TableUtils.makeBooleanValue(text, true);\n }\n if (TableUtils.isDateType(columnType)) {\n const [date] = DateUtils.parseDateRange(dh, text, timeZone);\n return date;\n }\n\n if (TableUtils.isNumberType(columnType)) {\n return TableUtils.makeNumberValue(text);\n }\n\n log.error('Unexpected column type', columnType);\n return null;\n }\n\n /**\n * Create a filter using the selected items\n * Has a flag for invertSelection as we start from a \"Select All\" state and a user just deselects items.\n * Since there may be millions of distinct items, it's easier to build an inverse filter.\n * @param column The column to set the filter on\n * @param selectedValues The values that are selected\n * @param invertSelection Invert the selection (eg. All items are selected, then you deselect items)\n * @returns Returns a `in` or `notIn` FilterCondition as necessary, or null if no filtering should be applied (everything selected)\n */\n makeSelectValueFilter<TInvert extends boolean>(\n column: Column,\n selectedValues: unknown[],\n invertSelection: TInvert\n ): TInvert extends true ? FilterCondition | null : FilterCondition {\n const { dh } = this;\n if (selectedValues.length === 0) {\n if (invertSelection) {\n // No filter means select everything\n return null as TInvert extends true\n ? FilterCondition | null\n : FilterCondition;\n }\n\n // KLUDGE: Return a conflicting filter to show no results.\n // Could recognize this situation at a higher or lower level and pause updates on the\n // table, but this situation should be rare and that wouldn't be much gains for some added complexity\n return this.makeNeverFilter(column);\n }\n\n const values = [];\n let isNullSelected = false;\n for (let i = 0; i < selectedValues.length; i += 1) {\n const value = selectedValues[i];\n if (value == null) {\n isNullSelected = true;\n } else if (TableUtils.isTextType(column.type)) {\n values.push(\n dh.FilterValue.ofString(\n typeof value === 'number' ? String.fromCharCode(value) : value\n )\n );\n } else if (TableUtils.isBooleanType(column.type)) {\n values.push(dh.FilterValue.ofBoolean(Boolean(value)));\n } else {\n values.push(dh.FilterValue.ofNumber(value));\n }\n }\n\n if (isNullSelected) {\n if (values.length > 0) {\n if (invertSelection) {\n return column\n .filter()\n .isNull()\n .not()\n .and(column.filter().notIn(values));\n }\n return column.filter().isNull().or(column.filter().in(values));\n }\n if (invertSelection) {\n return column.filter().isNull().not();\n }\n\n return column.filter().isNull();\n }\n\n if (invertSelection) {\n return column.filter().notIn(values);\n }\n\n return column.filter().in(values);\n }\n}\n\nexport default TableUtils;\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"TableUtils.js","names":["Type","FilterType","Operator","FilterOperator","Log","bindAllMethods","PromiseUtils","removeNullAndUndefined","TextUtils","TimeoutError","DateUtils","createValueFilter","getSize","log","module","TableUtils","copyTableAndApplyFilters","maybeTable","_arguments","arguments","_asyncToGenerator","derivedTable","copy","_len","length","filterFactories","Array","_key","applyFilter","map","f","getSortIndex","sort","columnName","i","_s$column","s","column","name","getSortForColumn","tableSort","sortIndex","getFilterText","filter","toString","getFilterTypes","columnType","isBooleanType","isTrue","isFalse","isNull","isCharType","isNumberType","isDateType","eq","notEq","greaterThan","greaterThanOrEqualTo","lessThan","lessThanOrEqualTo","isTextType","eqIgnoreCase","notEqIgnoreCase","contains","notContains","startsWith","endsWith","getNextSort","columns","sorts","columnIndex","asc","direction","sortDirection","ascending","desc","makeColumnSort","isAbs","none","descending","abs","toggleSortForColumn","addToExisting","undefined","newSort","setSortForColumn","sortColumn","modelColumn","concat","_ref","reverse","splice","push","getNormalizedType","dataType","BOOLEAN","CHAR","STRING","DATETIME","DECIMAL","INT","UNKNOWN","isLongType","isIntegerType","isDecimalType","isBigDecimalType","isBigIntegerType","isStringType","getBaseType","split","isCompatibleType","type1","type2","quoteValue","value","charAt","isRangeOperation","operation","makeRangeFilterWithOperation","makeCancelableTablePromise","table","makeCancelable","resolved","close","makeCancelableTableEventPromise","eventName","timeout","matcher","eventCleanup","timeoutId","isPending","wrappedPromise","Promise","resolve","reject","setTimeout","addEventListener","event","debug2","clearTimeout","cancel","removeCommas","replace","makeBooleanValue","text","allowEmpty","toLowerCase","Error","makeNumberValue","cleanText","trim","Number","POSITIVE_INFINITY","NEGATIVE_INFINITY","numberText","NUMBER_REGEX","test","parseFloat","getFilterOperatorString","isTreeTable","expand","collapse","sortColumns","isAscending","a","b","aName","toUpperCase","bName","constructor","dh","_defineProperty","createDistinctSortedColumnTable","_arguments2","_this","sourceTable","_len2","filterConditionFactories","_key2","findColumn","distinctTable","selectDistinct","distinctAscColSort","applySort","doesColumnValueExist","columnNames","isCaseSensitive","_this2","filterConditionFactory","tableCopy","size","makeQuickFilter","timeZone","orComponents","orFilter","orComponent","andComponents","andFilter","j","andComponent","makeQuickFilterFromComponent","and","or","type","makeQuickNumberFilter","makeQuickBooleanFilter","makeQuickDateFilter","makeQuickCharFilter","makeQuickTextFilter","columnFilter","regex","result","exec","negativeSign","abnormalValue","overflow","FilterCondition","invoke","FilterValue","ofNumber","not","LongWrapper","ofString","error","warn","isNaN","escapeQuickTextFilter","quickFilterText","_operation","_value2","nullRegex","_value","substring","unescapeQuickTextFilter","_operation2","_value3","prefix","suffix","notEqual","cleanValue","boolValue","e","dateText","filterOperation","makeQuickDateFilterWithOperation","startDate","endDate","parseDateRange","startValue","endValue","startFilter","endFilter","filterValue","makeAdvancedFilter","options","filterItems","filterOperators","invertSelection","selectedValues","filterItem","selectedType","newFilter","makeAdvancedValueFilter","filterOperator","err","selectValueFilter","makeSelectValueFilter","makeFilterValue","in","inIgnoreCase","notIn","notInIgnoreCase","applyNeverFilter","_arguments3","_this3","APPLY_TABLE_CHANGE_TIMEOUT_MS","filters","makeNeverFilter","applyCustomColumns","_arguments4","_this4","executeAndWaitForEvent","t","Table","EVENT_CUSTOMCOLUMNSCHANGED","_arguments5","_this5","EVENT_FILTERCHANGED","_arguments6","_this6","EVENT_SORTCHANGED","ofBoolean","DateWrapper","ofJsDate","Date","eqFilter","notEqFilter","makeFilterRawValue","rawValue","makeValue","date","values","isNullSelected","String","fromCharCode","Boolean","Object","freeze","NONE","PRE_SORT","POST_SORT","_ref2","eventType","eventPromise","_x","_x2","_x3","apply"],"sources":["../src/TableUtils.ts"],"sourcesContent":["import {\n Type as FilterType,\n Operator as FilterOperator,\n TypeValue as FilterTypeValue,\n OperatorValue as FilterOperatorValue,\n} from '@deephaven/filters';\nimport Log from '@deephaven/log';\nimport type {\n Column,\n CustomColumn,\n dh as DhType,\n FilterCondition,\n FilterValue,\n LongWrapper,\n RemoverFn,\n Sort,\n Table,\n TreeTable,\n} from '@deephaven/jsapi-types';\nimport {\n bindAllMethods,\n CancelablePromise,\n PromiseUtils,\n removeNullAndUndefined,\n TextUtils,\n TimeoutError,\n} from '@deephaven/utils';\nimport DateUtils from './DateUtils';\nimport { ColumnName } from './Formatter';\nimport { createValueFilter, FilterConditionFactory } from './FilterUtils';\nimport { getSize } from './ViewportDataUtils';\n\nconst log = Log.module('TableUtils');\n\ntype Values<T> = T[keyof T];\nexport type DataType = Values<typeof TableUtils.dataType>;\nexport type SortDirection = Values<typeof TableUtils.sortDirection>;\nexport type ReverseType = Values<typeof TableUtils.REVERSE_TYPE>;\nexport type AdvancedFilterItemType = {\n selectedType: FilterTypeValue;\n value: string;\n};\n\nexport interface FilterItem {\n selectedType: FilterTypeValue;\n value: string;\n}\n\nexport type AdvancedFilterOptions = {\n filterItems: FilterItem[];\n filterOperators: FilterOperatorValue[];\n invertSelection: boolean;\n selectedValues: unknown[];\n};\n\nexport type RowDataMapValue = {\n type: string;\n text: string;\n value: unknown;\n isExpandable: boolean;\n isGrouped: boolean;\n visibleIndex: number;\n};\n\nexport type RowDataMap = Record<ColumnName, RowDataMapValue>;\n\n/** Utility class to provide some functions for working with tables */\nexport class TableUtils {\n static dataType = {\n BOOLEAN: 'boolean',\n CHAR: 'char',\n DATETIME: 'datetime',\n DECIMAL: 'decimal',\n INT: 'int',\n STRING: 'string',\n UNKNOWN: 'unknown',\n } as const;\n\n static sortDirection = {\n ascending: 'ASC',\n descending: 'DESC',\n reverse: 'REVERSE',\n none: null,\n } as const;\n\n static APPLY_TABLE_CHANGE_TIMEOUT_MS = 30000;\n\n static REVERSE_TYPE = Object.freeze({\n NONE: 'none',\n PRE_SORT: 'pre-sort',\n POST_SORT: 'post-sort',\n } as const);\n\n // Regex looking for a negative or positive integer or decimal number\n static NUMBER_REGEX = /^-?\\d+(\\.\\d+)?$/;\n\n /**\n * Copy a given table and apply filters.\n * @param maybeTable Table to copy and apply filters to\n * @param filterFactories Filter condition factories to apply\n * @returns A derived, filtered table\n */\n static async copyTableAndApplyFilters<\n T extends Table | null | undefined,\n R extends T extends Table ? T : null,\n >(maybeTable: T, ...filterFactories: FilterConditionFactory[]): Promise<R> {\n if (maybeTable == null) {\n return null as R;\n }\n\n const derivedTable = await maybeTable.copy();\n\n derivedTable.applyFilter(\n removeNullAndUndefined(...filterFactories.map(f => f(derivedTable)))\n );\n\n return derivedTable as R;\n }\n\n /**\n * Executes a callback on a given table and returns a Promise that will resolve\n * the next time a particular event type fires on the table.\n * @param exec Callback function to execute.\n * @param table Table that gets passed to the `exec` function and that is\n * subscribed to for a given `eventType`.\n * @param eventType The event type to listen for.\n * @param timeout If the event doesn't fire within the timeout, the returned\n * Promise will be rejected.\n * @returns a Promise to the original table that resolves on next `eventType`\n * event\n */\n static executeAndWaitForEvent = async <T extends Table | TreeTable>(\n exec: (maybeTable: T | null | undefined) => void,\n table: T | null | undefined,\n eventType: string,\n timeout = TableUtils.APPLY_TABLE_CHANGE_TIMEOUT_MS\n ): Promise<T | null> => {\n if (table == null) {\n return null;\n }\n\n const eventPromise = TableUtils.makeCancelableTableEventPromise(\n table,\n eventType,\n timeout\n );\n\n exec(table);\n\n await eventPromise;\n\n return table;\n };\n\n static getSortIndex(\n sort: readonly Sort[],\n columnName: ColumnName\n ): number | null {\n for (let i = 0; i < sort.length; i += 1) {\n const s = sort[i];\n if (s.column?.name === columnName) {\n return i;\n }\n }\n\n return null;\n }\n\n /**\n * @param tableSort The sorts from the table to get the sort from\n * @param columnName The name of the column to get the sort for\n * @returns The sort for the column, or null if it's not sorted\n */\n static getSortForColumn(\n tableSort: readonly Sort[],\n columnName: ColumnName\n ): Sort | null {\n const sortIndex = TableUtils.getSortIndex(tableSort, columnName);\n if (sortIndex != null) {\n return tableSort[sortIndex];\n }\n return null;\n }\n\n static getFilterText(filter?: FilterCondition | null): string | null {\n if (filter) {\n return filter.toString();\n }\n return null;\n }\n\n /** Return the valid filter types for the column */\n static getFilterTypes(columnType: string): FilterTypeValue[] {\n if (TableUtils.isBooleanType(columnType)) {\n return [FilterType.isTrue, FilterType.isFalse, FilterType.isNull];\n }\n if (\n TableUtils.isCharType(columnType) ||\n TableUtils.isNumberType(columnType) ||\n TableUtils.isDateType(columnType)\n ) {\n return [\n FilterType.eq,\n FilterType.notEq,\n FilterType.greaterThan,\n FilterType.greaterThanOrEqualTo,\n FilterType.lessThan,\n FilterType.lessThanOrEqualTo,\n ];\n }\n if (TableUtils.isTextType(columnType)) {\n return [\n FilterType.eq,\n FilterType.eqIgnoreCase,\n FilterType.notEq,\n FilterType.notEqIgnoreCase,\n FilterType.contains,\n FilterType.notContains,\n FilterType.startsWith,\n FilterType.endsWith,\n ];\n }\n return [];\n }\n\n static getNextSort(\n columns: readonly Column[],\n sorts: readonly Sort[],\n columnIndex: number\n ): Sort | null {\n if (columnIndex < 0 || columnIndex >= columns.length) {\n return null;\n }\n\n const sort = TableUtils.getSortForColumn(sorts, columns[columnIndex].name);\n if (sort === null) {\n return columns[columnIndex].sort().asc();\n }\n if (sort.direction === TableUtils.sortDirection.ascending) {\n return sort.desc();\n }\n return null;\n }\n\n static makeColumnSort(\n columns: readonly Column[],\n columnIndex: number,\n direction: SortDirection,\n isAbs: boolean\n ): Sort | null {\n if (columnIndex < 0 || columnIndex >= columns.length) {\n return null;\n }\n\n if (direction === TableUtils.sortDirection.none) {\n return null;\n }\n\n let sort = columns[columnIndex].sort();\n\n switch (direction) {\n case TableUtils.sortDirection.ascending:\n sort = sort.asc();\n break;\n case TableUtils.sortDirection.descending:\n sort = sort.desc();\n break;\n default:\n break;\n }\n if (isAbs) {\n sort = sort.abs();\n }\n return sort;\n }\n\n /**\n * Toggles the sort for the specified column\n * @param sorts The current sorts from IrisGrid.state\n * @param columns The columns to apply the sort to\n * @param columnIndex The column index to apply the sort to\n * @param addToExisting Add this sort to the existing sort\n */\n static toggleSortForColumn(\n sorts: readonly Sort[],\n columns: readonly Column[],\n columnIndex: number,\n addToExisting = false\n ): Sort[] {\n if (columnIndex < 0 || columnIndex >= columns.length) {\n return [];\n }\n\n const newSort = TableUtils.getNextSort(columns, sorts, columnIndex);\n\n return TableUtils.setSortForColumn(\n sorts,\n columns[columnIndex].name,\n newSort,\n addToExisting\n );\n }\n\n static sortColumn(\n sorts: readonly Sort[],\n columns: readonly Column[],\n modelColumn: number,\n direction: SortDirection,\n isAbs: boolean,\n addToExisting: boolean\n ): Sort[] {\n if (modelColumn < 0 || modelColumn >= columns.length) {\n return [];\n }\n\n const newSort = TableUtils.makeColumnSort(\n columns,\n modelColumn,\n direction,\n isAbs\n );\n\n return TableUtils.setSortForColumn(\n sorts,\n columns[modelColumn].name,\n newSort,\n addToExisting\n );\n }\n\n /**\n * Sets the sort for the given column *and* removes any reverses\n * @param tableSort The current sorts from IrisGrid.state\n * @param columnName The column name to apply the sort to\n * @param sort The sort object to add\n * @param addToExisting Add this sort to the existing sort\n * @returns Returns the modified array of sorts - removing reverses\n */\n static setSortForColumn(\n tableSort: readonly Sort[],\n columnName: ColumnName,\n sort: Sort | null,\n addToExisting = false\n ): Sort[] {\n const sortIndex = TableUtils.getSortIndex(tableSort, columnName);\n let sorts: Sort[] = [];\n if (addToExisting) {\n sorts = sorts.concat(\n tableSort.filter(\n ({ direction }) => direction !== TableUtils.sortDirection.reverse\n )\n );\n if (sortIndex !== null) {\n sorts.splice(sortIndex, 1);\n }\n }\n\n if (sort !== null) {\n sorts.push(sort);\n }\n\n return sorts;\n }\n\n static getNormalizedType(columnType?: string | null): DataType {\n switch (columnType) {\n case 'boolean':\n case 'java.lang.Boolean':\n case TableUtils.dataType.BOOLEAN:\n return TableUtils.dataType.BOOLEAN;\n case 'char':\n case 'java.lang.Character':\n case TableUtils.dataType.CHAR:\n return TableUtils.dataType.CHAR;\n case 'java.lang.String':\n case TableUtils.dataType.STRING:\n return TableUtils.dataType.STRING;\n case 'io.deephaven.db.tables.utils.DBDateTime':\n case 'io.deephaven.time.DateTime':\n case 'com.illumon.iris.db.tables.utils.DBDateTime':\n case 'java.time.Instant':\n case 'java.time.ZonedDateTime':\n case TableUtils.dataType.DATETIME:\n return TableUtils.dataType.DATETIME;\n case 'double':\n case 'java.lang.Double':\n case 'float':\n case 'java.lang.Float':\n case 'java.math.BigDecimal':\n case TableUtils.dataType.DECIMAL:\n return TableUtils.dataType.DECIMAL;\n case 'int':\n case 'java.lang.Integer':\n case 'long':\n case 'java.lang.Long':\n case 'short':\n case 'java.lang.Short':\n case 'byte':\n case 'java.lang.Byte':\n case 'java.math.BigInteger':\n case TableUtils.dataType.INT:\n return TableUtils.dataType.INT;\n default:\n return TableUtils.dataType.UNKNOWN;\n }\n }\n\n static isLongType(columnType: string): boolean {\n switch (columnType) {\n case 'long':\n case 'java.lang.Long':\n return true;\n default:\n return false;\n }\n }\n\n static isDateType(columnType: string): boolean {\n switch (columnType) {\n case 'io.deephaven.db.tables.utils.DBDateTime':\n case 'io.deephaven.time.DateTime':\n case 'java.time.Instant':\n case 'java.time.ZonedDateTime':\n case 'com.illumon.iris.db.tables.utils.DBDateTime':\n return true;\n default:\n return false;\n }\n }\n\n static isNumberType(columnType: string): boolean {\n return (\n TableUtils.isIntegerType(columnType) ||\n TableUtils.isDecimalType(columnType)\n );\n }\n\n static isIntegerType(columnType: string): boolean {\n switch (columnType) {\n case 'int':\n case 'java.lang.Integer':\n case 'java.math.BigInteger':\n case 'long':\n case 'java.lang.Long':\n case 'short':\n case 'java.lang.Short':\n case 'byte':\n case 'java.lang.Byte':\n return true;\n default:\n return false;\n }\n }\n\n static isDecimalType(columnType: string): boolean {\n switch (columnType) {\n case 'double':\n case 'java.lang.Double':\n case 'java.math.BigDecimal':\n case 'float':\n case 'java.lang.Float':\n return true;\n default:\n return false;\n }\n }\n\n static isBigDecimalType(columnType: string): boolean {\n switch (columnType) {\n case 'java.math.BigDecimal':\n return true;\n default:\n return false;\n }\n }\n\n static isBigIntegerType(columnType: string): boolean {\n switch (columnType) {\n case 'java.math.BigInteger':\n return true;\n default:\n return false;\n }\n }\n\n static isBooleanType(columnType: string): boolean {\n switch (columnType) {\n case 'boolean':\n case 'java.lang.Boolean':\n return true;\n default:\n return false;\n }\n }\n\n static isCharType(columnType: string): boolean {\n switch (columnType) {\n case 'char':\n case 'java.lang.Character':\n return true;\n default:\n return false;\n }\n }\n\n static isStringType(columnType: string): boolean {\n switch (columnType) {\n case 'java.lang.String':\n return true;\n default:\n return false;\n }\n }\n\n static isTextType(columnType: string): boolean {\n return this.isStringType(columnType) || this.isCharType(columnType);\n }\n\n /**\n * Get base column type\n * @param columnType Column type\n * @returns Element type for array columns, original type for non-array columns\n */\n static getBaseType(columnType: string): string {\n return columnType.split('[]')[0];\n }\n\n /**\n * Check if the column types are compatible\n * @param type1 Column type to check\n * @param type2 Column type to check\n * @returns True, if types are compatible\n */\n static isCompatibleType(\n type1?: string | null,\n type2?: string | null\n ): boolean {\n return (\n TableUtils.getNormalizedType(type1) ===\n TableUtils.getNormalizedType(type2)\n );\n }\n\n /**\n * Adds quotes to a value if they're not already added\n * @param value Value to add quotes around\n */\n static quoteValue(value: string): string {\n if (\n value.length >= 2 &&\n ((value.charAt(0) === '\"' && value.charAt(value.length - 1) === '\"') ||\n (value.charAt(0) === \"'\" && value.charAt(value.length - 1) === \"'\"))\n ) {\n return value;\n }\n return `\"${value}\"`;\n }\n\n static isRangeOperation(operation: string): boolean {\n switch (operation) {\n case '<':\n case '<=':\n case '=<':\n case '>':\n case '>=':\n case '=>':\n return true;\n default:\n return false;\n }\n }\n\n /**\n * @param filter The column filter to apply the range operation to\n * @param operation The range operation to run\n * @param value The value to use for the operation\n * @returns The condition with the specified operation\n */\n static makeRangeFilterWithOperation(\n filter: FilterValue,\n operation: string,\n value: FilterValue\n ): FilterCondition | null {\n switch (operation) {\n case '=':\n return filter.eq(value);\n case '<':\n return filter.lessThan(value);\n case '<=':\n case '=<':\n return filter.lessThanOrEqualTo(value);\n case '>':\n return filter.greaterThan(value);\n case '>=':\n case '=>':\n return filter.greaterThanOrEqualTo(value);\n case '!=':\n case '!':\n return filter.notEq(value);\n default:\n return null;\n }\n }\n\n /**\n * Wraps a table promise in a cancelable promise that will close the table if the promise is cancelled.\n * Use in a component that loads a table, and call cancel when unmounting.\n * @param table The table promise to wrap\n */\n static makeCancelableTablePromise(\n table: Promise<Table> | Table\n ): CancelablePromise<Table> {\n return PromiseUtils.makeCancelable(table, resolved => {\n resolved.close();\n });\n }\n\n /**\n * Make a cancelable promise for a one-shot table event with a timeout.\n * @param table Table to listen for events on\n * @param eventName Event to listen for\n * @param timeout Event timeout in milliseconds, defaults to 0\n * @param matcher Optional function to determine if the promise can be resolved or stays pending\n * @returns Resolves with the event data\n */\n static makeCancelableTableEventPromise(\n table: Table | TreeTable,\n eventName: string,\n timeout = 0,\n matcher: ((event: CustomEvent) => boolean) | null = null\n ): CancelablePromise<CustomEvent> {\n let eventCleanup: RemoverFn;\n let timeoutId: ReturnType<typeof setTimeout>;\n let isPending = true;\n const wrappedPromise = new Promise((resolve, reject) => {\n timeoutId = setTimeout(() => {\n eventCleanup();\n isPending = false;\n reject(new TimeoutError(`Event \"${eventName}\" timed out.`));\n }, timeout);\n eventCleanup = table.addEventListener(eventName, event => {\n if (matcher != null && !matcher(event)) {\n log.debug2('Event triggered, but matcher returned false.');\n return;\n }\n log.debug2('Event triggered, resolving.');\n eventCleanup();\n clearTimeout(timeoutId);\n isPending = false;\n resolve(event);\n });\n }) as CancelablePromise<CustomEvent>;\n wrappedPromise.cancel = () => {\n if (isPending) {\n log.debug2('Pending promise cleanup.');\n eventCleanup();\n clearTimeout(timeoutId);\n isPending = false;\n return;\n }\n log.debug2('Ignoring non-pending promise cancel.');\n };\n return wrappedPromise;\n }\n\n static removeCommas(value: string): string {\n return value.replace(/[\\s|,]/g, '');\n }\n\n static makeBooleanValue(text: string, allowEmpty = false): boolean | null {\n if (text === '' && allowEmpty) {\n return null;\n }\n\n switch (text?.toLowerCase()) {\n case 'null':\n return null;\n case '0':\n case 'f':\n case 'fa':\n case 'fal':\n case 'fals':\n case 'false':\n case 'n':\n case 'no':\n return false;\n case '1':\n case 't':\n case 'tr':\n case 'tru':\n case 'true':\n case 'y':\n case 'ye':\n case 'yes':\n return true;\n default:\n throw new Error(`Invalid boolean '${text}'`);\n }\n }\n\n static makeNumberValue(text: string): number | null {\n if (text === 'null' || text === '') {\n return null;\n }\n\n const cleanText = text.toLowerCase().trim();\n if (cleanText === '∞' || cleanText === 'infinity' || cleanText === 'inf') {\n return Number.POSITIVE_INFINITY;\n }\n if (\n cleanText === '-∞' ||\n cleanText === '-infinity' ||\n cleanText === '-inf'\n ) {\n return Number.NEGATIVE_INFINITY;\n }\n\n const numberText = TableUtils.removeCommas(cleanText);\n if (TableUtils.NUMBER_REGEX.test(numberText)) {\n return parseFloat(numberText);\n }\n\n throw new Error(`Invalid number '${text}'`);\n }\n\n static getFilterOperatorString(operation: FilterTypeValue): string {\n switch (operation) {\n case FilterType.eq:\n return '=';\n case FilterType.notEq:\n return '!=';\n case FilterType.greaterThan:\n return '>';\n case FilterType.greaterThanOrEqualTo:\n return '>=';\n case FilterType.lessThan:\n return '<';\n case FilterType.lessThanOrEqualTo:\n return '<=';\n case FilterType.contains:\n return '~';\n case FilterType.notContains:\n return '!~';\n default:\n throw new Error(`Unexpected filter type ${operation}`);\n }\n }\n\n static isTreeTable(table: unknown): table is TreeTable {\n return (\n table != null &&\n (table as TreeTable).expand !== undefined &&\n (table as TreeTable).collapse !== undefined\n );\n }\n\n /**\n * Copies the provided array, sorts by column name case insensitive, and returns the sorted array.\n * @param columns The columns to sort\n * @param isAscending Whether to sort ascending\n */\n static sortColumns(columns: readonly Column[], isAscending = true): Column[] {\n return [...columns].sort((a, b) => {\n const aName = a.name.toUpperCase();\n const bName = b.name.toUpperCase();\n return TextUtils.sort(aName, bName, isAscending);\n });\n }\n\n dh: DhType;\n\n constructor(dh: DhType) {\n this.dh = dh;\n bindAllMethods(this);\n }\n\n /**\n * Create a table containing a distinct list of values for given column name and\n * applies the given sort direction.\n * @param table Source table to derive table from\n * @param columnName Column to dermine distinct values\n * @param sortDirection Direction to sort\n * @param filterConditionFactories Optional filters to apply. Note that these\n * will be applied before the `selectCall` in case we need to base the filtering\n * on columns other than the distinct value column\n */\n async createDistinctSortedColumnTable(\n table: Table | null | undefined,\n columnName: string,\n sortDirection: 'asc' | 'desc',\n ...filterConditionFactories: FilterConditionFactory[]\n ): Promise<Table | null> {\n if (table == null) {\n return null;\n }\n\n let sourceTable = table;\n\n // Applying filters before `selectDistinct` so that we still have access to\n // all columns. Also prevents a filter applied to the final table from\n // clearing this filter.\n if (filterConditionFactories.length > 0) {\n sourceTable = await table.copy();\n\n await sourceTable.applyFilter(\n removeNullAndUndefined(\n ...filterConditionFactories.map(f => f(sourceTable))\n )\n );\n }\n\n const column = sourceTable.findColumn(columnName);\n const distinctTable = await sourceTable.selectDistinct([column]);\n\n // If we copied the table, dispose the copy. Original is managed outside\n // of this function\n if (sourceTable !== table) {\n sourceTable.close();\n }\n\n const distinctAscColSort = distinctTable\n .findColumn(columnName)\n .sort()\n [sortDirection]();\n\n return this.applySort(distinctTable, [distinctAscColSort]);\n }\n\n /**\n * Check if any columns contain a given value.\n * @param table Table to search for values\n * @param columnNames Column names to search\n * @param value Value to search for\n * @param isCaseSensitive Whether the value check is case sensitive\n */\n async doesColumnValueExist(\n table: Table | null | undefined,\n columnNames: string | string[],\n value: string,\n isCaseSensitive: boolean\n ): Promise<boolean | null> {\n if (table == null) {\n return null;\n }\n\n const filterConditionFactory = createValueFilter(\n this,\n columnNames,\n value,\n isCaseSensitive ? 'eq' : 'eqIgnoreCase'\n );\n\n const tableCopy = await table.copy();\n\n await this.applyFilter(\n tableCopy,\n removeNullAndUndefined(filterConditionFactory(tableCopy))\n );\n\n const size = getSize(tableCopy);\n\n tableCopy.close();\n\n return size > 0;\n }\n\n /**\n * Create filter with the provided column and text. Handles multiple filters joined with && or ||\n * @param column The column to set the filter on\n * @param text The text string to create the filter from\n * @param timeZone The time zone to make this value in if it is a date type. E.g. America/New_York\n * @returns Returns the created filter, null if text could not be parsed\n */\n makeQuickFilter(\n column: Column,\n text: string,\n timeZone?: string\n ): FilterCondition | null {\n const orComponents = text.split('||');\n let orFilter = null;\n for (let i = 0; i < orComponents.length; i += 1) {\n const orComponent = orComponents[i];\n const andComponents = orComponent.split('&&');\n let andFilter = null;\n for (let j = 0; j < andComponents.length; j += 1) {\n const andComponent = andComponents[j].trim();\n if (andComponent.length > 0) {\n const filter = this.makeQuickFilterFromComponent(\n column,\n andComponent,\n timeZone\n );\n if (filter) {\n if (andFilter) {\n andFilter = andFilter.and(filter);\n } else {\n andFilter = filter;\n }\n } else {\n throw new Error(`Unable to parse quick filter from text ${text}`);\n }\n }\n }\n\n if (orFilter && andFilter) {\n orFilter = orFilter.or(andFilter);\n } else {\n orFilter = andFilter;\n }\n }\n\n return orFilter;\n }\n\n /**\n * Create filter with the provided column and text of one component (no multiple conditions)\n * @param column The column to set the filter on\n * @param text The text string to create the filter from\n * @param timeZone The time zone to make this filter in if it is a date type. E.g. America/New_York\n * @returns Returns the created filter, null if text could not be parsed\n */\n makeQuickFilterFromComponent(\n column: Column,\n text: string,\n timeZone?: string\n ): FilterCondition | null {\n const { type } = column;\n if (TableUtils.isNumberType(type)) {\n return this.makeQuickNumberFilter(column, text);\n }\n if (TableUtils.isBooleanType(type)) {\n return this.makeQuickBooleanFilter(column, text);\n }\n if (timeZone != null && TableUtils.isDateType(type)) {\n return this.makeQuickDateFilter(column, text, timeZone);\n }\n if (TableUtils.isCharType(type)) {\n return this.makeQuickCharFilter(column, text);\n }\n return this.makeQuickTextFilter(column, text);\n }\n\n makeQuickNumberFilter(column: Column, text: string): FilterCondition | null {\n const columnFilter = column.filter();\n const { dh } = this;\n let filter = null;\n\n const regex =\n /\\s*(>=|<=|=>|=<|>|<|!=|=|!)?(\\s*-\\s*)?(\\s*\\d*(?:,\\d{3})*(?:\\.\\d*)?\\s*)?(null|nan|infinity|inf|\\u221E)?(.*)/i;\n const result = regex.exec(text);\n\n let operation = null;\n let negativeSign = null;\n let value = null;\n let abnormalValue = null; // includes nan, null and infinity(positive & negative)\n let overflow = null;\n\n if (result !== null && result.length > 3) {\n [, operation, negativeSign, value, abnormalValue, overflow] = result;\n }\n\n if (overflow != null && overflow.trim().length > 0) {\n // Some bad characters after the number, bail out!\n return null;\n }\n\n if (operation == null) {\n operation = '=';\n }\n\n if (abnormalValue != null) {\n if (!(operation === '=' || operation === '!' || operation === '!=')) {\n // only equal and not equal operations are supported for abnormal value filter\n return null;\n }\n abnormalValue = abnormalValue.trim().toLowerCase();\n switch (abnormalValue) {\n case 'null':\n filter = columnFilter.isNull();\n break;\n case 'nan':\n filter = dh.FilterCondition.invoke('isNaN', columnFilter);\n break;\n case 'infinity':\n case 'inf':\n case '\\u221E':\n if (negativeSign != null) {\n filter = dh.FilterCondition.invoke('isInf', columnFilter).and(\n columnFilter.lessThan(dh.FilterValue.ofNumber(0))\n );\n } else {\n filter = dh.FilterCondition.invoke('isInf', columnFilter).and(\n columnFilter.greaterThan(dh.FilterValue.ofNumber(0))\n );\n }\n break;\n default:\n break;\n }\n if (filter !== null && (operation === '!' || operation === '!=')) {\n filter = filter.not();\n }\n return filter;\n }\n\n if (value == null) {\n return null;\n }\n\n value = TableUtils.removeCommas(value);\n if (TableUtils.isLongType(column.type)) {\n try {\n value = dh.FilterValue.ofNumber(\n dh.LongWrapper.ofString(`${negativeSign != null ? '-' : ''}${value}`)\n );\n } catch (error) {\n log.warn('Unable to create long filter', error);\n return null;\n }\n } else {\n value = parseFloat(value);\n if (value == null || Number.isNaN(value)) {\n return null;\n }\n\n value = dh.FilterValue.ofNumber(negativeSign != null ? 0 - value : value);\n }\n\n filter = column.filter();\n\n return TableUtils.makeRangeFilterWithOperation(filter, operation, value);\n }\n\n /**\n * Given a text string from a table, escape quick filter operators in string with \\\n * ex. =test returns \\=test, null returns \\null\n * @param string quickfilter string to escape\n * @returns escaped string\n */\n static escapeQuickTextFilter(quickFilterText: string | null): string | null {\n if (quickFilterText == null) return null;\n const regex = /^(!~|!=|~|=|!)?(.*)/;\n // starts with zero or more \\ followed by and ending with null\n const nullRegex = /^\\\\*null$/;\n const result = regex.exec(quickFilterText);\n let operation: string | null = null;\n let value: string | null = null;\n if (result !== null && result.length > 2) {\n [, operation, value] = result;\n }\n\n if (operation != null) {\n return `\\\\${operation}${value ?? ''}`;\n }\n\n if (value != null && nullRegex.test(value.toLowerCase())) {\n // adds an extra escape character to matching value\n return `\\\\${value}`;\n }\n if (value != null && value.startsWith('*')) {\n return `\\\\${value}`;\n }\n if (value != null && value.endsWith('*') && !value.endsWith('\\\\*')) {\n value = value.substring(0, value.length - 1);\n return `${value}\\\\*`;\n }\n\n return `${operation ?? ''}${value ?? ``}`;\n }\n\n /**\n * Given an escaped quick filter, unescape the operators for giving it to the js api\n * ex. \\=test returns =test, \\null returns null\n * @param string quickfilter string to escape\n * @returns escaped string\n */\n static unescapeQuickTextFilter(quickFilterText: string): string {\n const regex = /^(\\\\!~|\\\\!=|\\\\~|\\\\=|\\\\!)?(.*)/;\n // starts with zero or more \\ followed by and ending with null\n const nullRegex = /^\\\\*null$/;\n const result = regex.exec(quickFilterText);\n let operation: string | null = null;\n let value: string | null = null;\n if (result !== null && result.length > 2) {\n [, operation, value] = result;\n }\n\n if (operation != null) {\n operation = operation.replace('\\\\', '');\n }\n\n if (value != null && nullRegex.test(value.toLowerCase())) {\n // removes the first occurance of the backslash\n value = value.replace('\\\\', '');\n }\n if (operation == null && value != null && value.startsWith('\\\\*')) {\n value = value.substring(1);\n }\n if (operation == null && value != null && value.endsWith('\\\\*')) {\n value = value.substring(0, value.length - 2);\n return `${value}*`;\n }\n\n return `${operation ?? ''}${value ?? ``}`;\n }\n\n makeQuickTextFilter(column: Column, text: string): FilterCondition | null {\n const { dh } = this;\n const cleanText = `${text}`.trim();\n const regex = /^(!~|!=|~|=|!)?(.*)/;\n const result = regex.exec(cleanText);\n\n let operation = null;\n let value = null;\n if (result !== null && result.length > 2) {\n [, operation, value] = result;\n if (value != null) {\n value = value.trim();\n }\n }\n\n if (value == null) {\n return null;\n }\n\n // allow empty strings, but only for explicit equal and not equal\n if (value.length === 0 && !(operation === '=' || operation === '!=')) {\n return null;\n }\n\n // no operation is treated as an implicit equals\n if (operation == null) {\n operation = '=';\n }\n\n const filter = column.filter();\n if (value.toLowerCase() === 'null') {\n // Null is a special case!\n switch (operation) {\n case '=':\n return filter.isNull();\n case '!=':\n case '!':\n return filter.isNull().not();\n default:\n // For all other operations, treat null as a string value\n }\n }\n\n let prefix = null;\n let suffix = null;\n if (value.startsWith('*')) {\n prefix = '*';\n value = value.substring(1);\n } else if (value.endsWith('*') && !value.endsWith('\\\\*')) {\n suffix = '*';\n value = value.substring(0, value.length - 1);\n }\n\n // unescape any escaped operators to allow search for literal operators\n value = TableUtils.unescapeQuickTextFilter(value);\n\n switch (operation) {\n case '~': {\n return filter\n .isNull()\n .not()\n .and(\n filter.invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i).*\\\\Q${value}\\\\E.*`)\n )\n );\n }\n case '!~':\n return filter\n .isNull()\n .or(\n filter\n .invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i).*\\\\Q${value}\\\\E.*`)\n )\n .not()\n );\n case '!=':\n if (prefix === '*') {\n // Does not end with\n return filter\n .isNull()\n .or(\n filter\n .invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i).*\\\\Q${value}\\\\E$`)\n )\n .not()\n );\n }\n if (suffix === '*') {\n // Does not start with\n return filter\n .isNull()\n .or(\n filter\n .invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i)^\\\\Q${value}\\\\E.*`)\n )\n .not()\n );\n }\n return filter.notEqIgnoreCase(\n dh.FilterValue.ofString(value.toLowerCase())\n );\n case '=':\n if (prefix === '*') {\n // Ends with\n return filter\n .isNull()\n .not()\n .and(\n filter.invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i).*\\\\Q${value}\\\\E$`)\n )\n );\n }\n if (suffix === '*') {\n // Starts with\n return filter\n .isNull()\n .not()\n .and(\n filter.invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i)^\\\\Q${value}\\\\E.*`)\n )\n );\n }\n return filter.eqIgnoreCase(\n dh.FilterValue.ofString(value.toLowerCase())\n );\n\n default:\n break;\n }\n\n return null;\n }\n\n // eslint-disable-next-line class-methods-use-this\n makeQuickBooleanFilter(\n column: Column,\n text: string | number\n ): FilterCondition | null {\n const regex = /^(!=|=|!)?(.*)/;\n const result = regex.exec(`${text}`.trim());\n if (result === null) {\n return null;\n }\n const [, operation, value] = result;\n const notEqual = operation === '!' || operation === '!=';\n const cleanValue = value.trim().toLowerCase();\n\n let filter: FilterCondition | FilterValue = column.filter();\n\n try {\n const boolValue = TableUtils.makeBooleanValue(cleanValue);\n if (boolValue != null && boolValue) {\n filter = filter.isTrue();\n } else if (boolValue === null) {\n filter = filter.isNull();\n } else {\n filter = filter.isFalse();\n }\n\n return notEqual ? filter.not() : filter;\n } catch (e) {\n return null;\n }\n }\n\n /**\n * Builds a date filter parsed from the text string which may or may not include an operator.\n * @param column The column to build the filter from, with or without a leading operator.\n * @param text The date string text to parse.\n * @param timeZone The time zone to make this filter in if it is a date type. E.g. America/New_York\n */\n makeQuickDateFilter(\n column: Column,\n text: string,\n timeZone: string\n ): FilterCondition {\n const cleanText = text.trim();\n const regex = /\\s*(>=|<=|=>|=<|>|<|!=|!|=)?(.*)/;\n const result = regex.exec(cleanText);\n if (result == null || result.length <= 2) {\n throw new Error(`Unable to parse date filter: ${text}`);\n }\n\n let operation = null;\n let dateText = null;\n\n [, operation, dateText] = result;\n\n let filterOperation: FilterTypeValue = FilterType.eq;\n switch (operation) {\n case '<':\n filterOperation = FilterType.lessThan;\n break;\n case '<=':\n case '=<':\n filterOperation = FilterType.lessThanOrEqualTo;\n break;\n case '>':\n filterOperation = FilterType.greaterThan;\n break;\n case '>=':\n case '=>':\n filterOperation = FilterType.greaterThanOrEqualTo;\n break;\n case '!=':\n case '!':\n filterOperation = FilterType.notEq;\n break;\n case '=':\n case '==':\n default:\n filterOperation = FilterType.eq;\n break;\n }\n\n return this.makeQuickDateFilterWithOperation(\n column,\n dateText,\n filterOperation,\n timeZone\n );\n }\n\n /**\n * Builds a date filter parsed from the text string with the provided filter.\n * @param column The column to build the filter from.\n * @param text The date string text to parse, without an operator.\n * @param operation The filter operation to use.\n * @param timeZone The time zone to make this filter with. E.g. America/New_York\n */\n makeQuickDateFilterWithOperation(\n column: Column,\n text: string,\n operation: FilterTypeValue,\n timeZone: string\n ): FilterCondition {\n const { dh } = this;\n const [startDate, endDate] = DateUtils.parseDateRange(dh, text, timeZone);\n\n const startValue =\n startDate != null ? dh.FilterValue.ofNumber(startDate) : null;\n const endValue = endDate != null ? dh.FilterValue.ofNumber(endDate) : null;\n\n const filter = column.filter();\n if (startValue == null) {\n return operation === FilterType.notEq\n ? filter.isNull().not()\n : filter.isNull();\n }\n\n switch (operation) {\n case FilterType.eq: {\n if (endValue != null) {\n const startFilter = filter.greaterThanOrEqualTo(startValue);\n const endFilter = filter.lessThan(endValue);\n return startFilter.and(endFilter);\n }\n return filter.eq(startValue);\n }\n case FilterType.lessThan: {\n return filter.lessThan(startValue);\n }\n case FilterType.lessThanOrEqualTo: {\n if (endValue != null) {\n return filter.lessThan(endValue);\n }\n return filter.lessThanOrEqualTo(startValue);\n }\n case FilterType.greaterThan: {\n if (endValue != null) {\n return filter.greaterThanOrEqualTo(endValue);\n }\n return filter.greaterThan(startValue);\n }\n case FilterType.greaterThanOrEqualTo:\n return filter.greaterThanOrEqualTo(startValue);\n case FilterType.notEq: {\n if (endValue != null) {\n const startFilter = filter.lessThan(startValue);\n const endFilter = filter.greaterThanOrEqualTo(endValue);\n return startFilter.or(endFilter);\n }\n return filter.notEq(startValue);\n }\n\n default:\n throw new Error(`Invalid operator: ${operation}`);\n }\n }\n\n makeQuickCharFilter(column: Column, text: string): FilterCondition | null {\n const { dh } = this;\n const cleanText = `${text}`.trim();\n const regex = /^(>=|<=|=>|=<|>|<|!=|=|!)?(null|\".\"|'.'|.)?(.*)/;\n const result = regex.exec(cleanText);\n\n let operation = null;\n let value = null;\n let overflow = null;\n if (result !== null && result.length > 3) {\n [, operation, value, overflow] = result;\n }\n if (overflow != null && overflow.trim().length > 0) {\n // Some bad characters after the number, bail out!\n return null;\n }\n\n if (value == null || value.length === 0) {\n return null;\n }\n\n if (operation == null) {\n operation = '=';\n }\n\n const filter = column.filter();\n if (value.toLowerCase() === 'null') {\n // Null is a special case!\n switch (operation) {\n case '=':\n return filter.isNull();\n case '!=':\n case '!':\n return filter.isNull().not();\n default:\n return null;\n }\n }\n\n // We need to put quotes around range operations or else the API fails\n const filterValue = dh.FilterValue.ofString(\n TableUtils.isRangeOperation(operation)\n ? TableUtils.quoteValue(value)\n : value\n );\n return TableUtils.makeRangeFilterWithOperation(\n filter,\n operation,\n filterValue\n );\n }\n\n makeAdvancedFilter(\n column: Column,\n options: AdvancedFilterOptions,\n timeZone: string\n ): FilterCondition | null {\n const { filterItems, filterOperators, invertSelection, selectedValues } =\n options;\n let filter = null;\n for (let i = 0; i < filterItems.length; i += 1) {\n const filterItem = filterItems[i];\n const { selectedType, value } = filterItem;\n if (\n selectedType != null &&\n selectedType.length > 0 &&\n value != null &&\n value.length > 0\n ) {\n try {\n const newFilter = this.makeAdvancedValueFilter(\n column,\n selectedType,\n value,\n timeZone\n );\n if (newFilter != null) {\n if (i === 0) {\n filter = newFilter;\n } else if (filter !== null && i - 1 < filterOperators.length) {\n const filterOperator = filterOperators[i - 1];\n if (filterOperator === FilterOperator.and) {\n filter = filter.and(newFilter);\n } else if (filterOperator === FilterOperator.or) {\n filter = filter.or(newFilter);\n } else {\n log.error(\n 'Unexpected filter operator',\n filterOperator,\n newFilter\n );\n filter = null;\n break;\n }\n }\n } else {\n log.debug2('Empty filter ignored for', selectedType, value);\n }\n } catch (err) {\n log.error('Unable to create filter', err);\n filter = null;\n break;\n }\n }\n }\n\n const selectValueFilter = this.makeSelectValueFilter(\n column,\n selectedValues,\n invertSelection\n );\n if (selectValueFilter != null) {\n if (filter != null) {\n filter = filter.and(selectValueFilter);\n } else {\n filter = selectValueFilter;\n }\n }\n\n return filter;\n }\n\n makeAdvancedValueFilter(\n column: Column,\n operation: FilterTypeValue,\n value: string,\n timeZone: string\n ): FilterCondition | null {\n const { dh } = this;\n if (TableUtils.isDateType(column.type)) {\n return this.makeQuickDateFilterWithOperation(\n column,\n value,\n operation,\n timeZone\n );\n }\n\n if (\n TableUtils.isNumberType(column.type) ||\n TableUtils.isCharType(column.type)\n ) {\n return this.makeQuickFilter(\n column,\n `${TableUtils.getFilterOperatorString(operation)}${value}`\n );\n }\n\n const filterValue = this.makeFilterValue(column.type, value);\n const filter = column.filter();\n switch (operation) {\n case FilterType.eq:\n return filter.eq(filterValue);\n case FilterType.eqIgnoreCase:\n return filter.eqIgnoreCase(filterValue);\n case FilterType.notEq:\n return filter.notEq(filterValue);\n case FilterType.notEqIgnoreCase:\n return filter.notEqIgnoreCase(filterValue);\n case FilterType.greaterThan:\n return filter.greaterThan(filterValue);\n case FilterType.greaterThanOrEqualTo:\n return filter.greaterThanOrEqualTo(filterValue);\n case FilterType.lessThan:\n return filter.lessThan(filterValue);\n case FilterType.lessThanOrEqualTo:\n return filter.lessThanOrEqualTo(filterValue);\n case FilterType.isTrue:\n return filter.isTrue();\n case FilterType.isFalse:\n return filter.isFalse();\n case FilterType.isNull:\n return filter.isNull();\n case FilterType.contains:\n return filter\n .isNull()\n .not()\n .and(\n filter.invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i).*\\\\Q${value}\\\\E.*`)\n )\n );\n case FilterType.notContains:\n return filter\n .isNull()\n .or(\n filter\n .invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i).*\\\\Q${value}\\\\E.*`)\n )\n .not()\n );\n case FilterType.startsWith:\n return filter\n .isNull()\n .not()\n .and(\n filter.invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i)^\\\\Q${value}\\\\E.*`)\n )\n );\n case FilterType.endsWith:\n return filter\n .isNull()\n .not()\n .and(\n filter.invoke(\n 'matches',\n dh.FilterValue.ofString(`(?s)(?i).*\\\\Q${value}\\\\E$`)\n )\n );\n case FilterType.in:\n case FilterType.inIgnoreCase:\n case FilterType.notIn:\n case FilterType.notInIgnoreCase:\n case FilterType.invoke:\n default:\n throw new Error(`Unexpected filter operation: ${operation}`);\n }\n }\n\n /**\n * Apply a filter to a table that won't match anything.\n * @table The table to apply the filter to\n * @columnName The name of the column to apploy the filter to\n * @param timeout Timeout before cancelling the promise that waits for the next\n * dh.Table.EVENT_FILTERCHANGED event\n * @returns a Promise to the Table that resolves after the next\n * dh.Table.EVENT_FILTERCHANGED event\n */\n async applyNeverFilter<T extends Table | TreeTable>(\n table: T | null | undefined,\n columnName: string,\n timeout = TableUtils.APPLY_TABLE_CHANGE_TIMEOUT_MS\n ): Promise<T | null> {\n if (table == null) {\n return null;\n }\n\n const column = table.findColumn(columnName);\n const filters = [this.makeNeverFilter(column)];\n\n await this.applyFilter(table, filters, timeout);\n\n return table;\n }\n\n /**\n * Apply custom columns to a given table. Return a Promise that resolves with\n * the table once the dh.Table.EVENT_CUSTOMCOLUMNSCHANGED event has fired.\n * @param table The table to apply custom columns to.\n * @param columns The list of column expressions or definitions to apply.\n * @returns A Promise that will be resolved with the given table after the\n * columns are applied.\n */\n async applyCustomColumns(\n table: Table | null | undefined,\n columns: (string | CustomColumn)[],\n timeout = TableUtils.APPLY_TABLE_CHANGE_TIMEOUT_MS\n ): Promise<Table | null> {\n const { dh } = this;\n return TableUtils.executeAndWaitForEvent(\n t => t?.applyCustomColumns(columns),\n table,\n dh.Table.EVENT_CUSTOMCOLUMNSCHANGED,\n timeout\n );\n }\n\n /**\n * Apply filters to a given table.\n * @param table Table to apply filters to\n * @param filters Filters to apply\n * @param timeout Timeout before cancelling the promise that waits for the next\n * dh.Table.EVENT_FILTERCHANGED event\n * @returns a Promise to the Table that resolves after the next\n * dh.Table.EVENT_FILTERCHANGED event\n */\n async applyFilter<T extends Table | TreeTable>(\n table: T | null | undefined,\n filters: FilterCondition[],\n timeout = TableUtils.APPLY_TABLE_CHANGE_TIMEOUT_MS\n ): Promise<T | null> {\n const { dh } = this;\n return TableUtils.executeAndWaitForEvent(\n t => t?.applyFilter(filters),\n table,\n dh.Table.EVENT_FILTERCHANGED,\n timeout\n );\n }\n\n /**\n * Apply sorts to a given Table.\n * @param table The table to apply sorts to\n * @param sorts The sorts to apply\n * @param timeout Timeout before cancelling the promise that waits for the next\n * dh.Table.EVENT_SORTCHANGED event\n * @returns a Promise to the Table that resolves after the next\n * dh.Table.EVENT_SORTCHANGED event\n */\n async applySort<T extends Table | TreeTable>(\n table: T | null | undefined,\n sorts: Sort[],\n timeout = TableUtils.APPLY_TABLE_CHANGE_TIMEOUT_MS\n ): Promise<T | null> {\n const { dh } = this;\n return TableUtils.executeAndWaitForEvent(\n t => t?.applySort(sorts),\n table,\n dh.Table.EVENT_SORTCHANGED,\n timeout\n );\n }\n\n /**\n * Create a filter condition that results in zero results for a given column\n * @param column\n */\n makeNeverFilter(column: Column): FilterCondition {\n const { dh } = this;\n let value = null;\n\n if (TableUtils.isTextType(column.type)) {\n // Use 'a' so that it can work for String or Character types\n value = dh.FilterValue.ofString('a');\n } else if (TableUtils.isBooleanType(column.type)) {\n value = dh.FilterValue.ofBoolean(true);\n } else if (TableUtils.isDateType(column.type)) {\n value = dh.FilterValue.ofNumber(dh.DateWrapper.ofJsDate(new Date()));\n } else {\n value = dh.FilterValue.ofNumber(0);\n }\n\n const eqFilter = column.filter().eq(value);\n const notEqFilter = column.filter().notEq(value);\n\n return eqFilter.and(notEqFilter);\n }\n\n /**\n * @param columnType The column type to make the filter value from.\n * @param value The value to make the filter value from.\n * @returns The FilterValue item for this column/value combination\n */\n makeFilterValue(columnType: string, value: string): FilterValue {\n const { dh } = this;\n const type = TableUtils.getBaseType(columnType);\n if (TableUtils.isTextType(type)) {\n return dh.FilterValue.ofString(value);\n }\n if (TableUtils.isLongType(type)) {\n return dh.FilterValue.ofNumber(\n dh.LongWrapper.ofString(TableUtils.removeCommas(value))\n );\n }\n\n return dh.FilterValue.ofNumber(TableUtils.removeCommas(value));\n }\n\n /**\n * Takes a value and converts it to an `dh.FilterValue`\n *\n * @param columnType The column type to make the filter value from.\n * @param value The value to actually set\n * @returns The FilterValue item for this column/value combination\n */\n makeFilterRawValue(columnType: string, rawValue: unknown): FilterValue {\n const { dh } = this;\n if (TableUtils.isTextType(columnType)) {\n return dh.FilterValue.ofString(rawValue);\n }\n\n if (TableUtils.isBooleanType(columnType)) {\n return dh.FilterValue.ofBoolean(rawValue);\n }\n\n return dh.FilterValue.ofNumber(rawValue);\n }\n\n /**\n * Converts a string value to a value appropriate for the column\n * @param columnType The column type to make the value for\n * @param text The string value to make a type for\n * @param timeZone The time zone to make this value in if it is a date type. E.g. America/New_York\n */\n makeValue(\n columnType: string,\n text: string,\n timeZone: string\n ): string | number | boolean | LongWrapper | null {\n const { dh } = this;\n if (text === 'null') {\n return null;\n }\n if (TableUtils.isTextType(columnType)) {\n return text;\n }\n if (TableUtils.isLongType(columnType)) {\n return dh.LongWrapper.ofString(TableUtils.removeCommas(text));\n }\n if (TableUtils.isBooleanType(columnType)) {\n return TableUtils.makeBooleanValue(text, true);\n }\n if (TableUtils.isDateType(columnType)) {\n const [date] = DateUtils.parseDateRange(dh, text, timeZone);\n return date;\n }\n\n if (TableUtils.isNumberType(columnType)) {\n return TableUtils.makeNumberValue(text);\n }\n\n log.error('Unexpected column type', columnType);\n return null;\n }\n\n /**\n * Create a filter using the selected items\n * Has a flag for invertSelection as we start from a \"Select All\" state and a user just deselects items.\n * Since there may be millions of distinct items, it's easier to build an inverse filter.\n * @param column The column to set the filter on\n * @param selectedValues The values that are selected\n * @param invertSelection Invert the selection (eg. All items are selected, then you deselect items)\n * @returns Returns a `in` or `notIn` FilterCondition as necessary, or null if no filtering should be applied (everything selected)\n */\n makeSelectValueFilter<TInvert extends boolean>(\n column: Column,\n selectedValues: unknown[],\n invertSelection: TInvert\n ): TInvert extends true ? FilterCondition | null : FilterCondition {\n const { dh } = this;\n if (selectedValues.length === 0) {\n if (invertSelection) {\n // No filter means select everything\n return null as TInvert extends true\n ? FilterCondition | null\n : FilterCondition;\n }\n\n // KLUDGE: Return a conflicting filter to show no results.\n // Could recognize this situation at a higher or lower level and pause updates on the\n // table, but this situation should be rare and that wouldn't be much gains for some added complexity\n return this.makeNeverFilter(column);\n }\n\n const values = [];\n let isNullSelected = false;\n for (let i = 0; i < selectedValues.length; i += 1) {\n const value = selectedValues[i];\n if (value == null) {\n isNullSelected = true;\n } else if (TableUtils.isTextType(column.type)) {\n values.push(\n dh.FilterValue.ofString(\n typeof value === 'number' ? String.fromCharCode(value) : value\n )\n );\n } else if (TableUtils.isBooleanType(column.type)) {\n values.push(dh.FilterValue.ofBoolean(Boolean(value)));\n } else {\n values.push(dh.FilterValue.ofNumber(value));\n }\n }\n\n if (isNullSelected) {\n if (values.length > 0) {\n if (invertSelection) {\n return column\n .filter()\n .isNull()\n .not()\n .and(column.filter().notIn(values));\n }\n return column.filter().isNull().or(column.filter().in(values));\n }\n if (invertSelection) {\n return column.filter().isNull().not();\n }\n\n return column.filter().isNull();\n }\n\n if (invertSelection) {\n return column.filter().notIn(values);\n }\n\n return column.filter().in(values);\n }\n}\n\nexport default TableUtils;\n"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ViewportDataUtils.js","names":["clamp","Log","log","module","createKeyFromOffsetRow","row","offset","String","offsetInSnapshot","createOnTableUpdatedHandler","deserializeRow","bulkUpdate","onTableUpdated","event","columns","rows","detail","debug","updateKeyMap","Map","forEach","item","key","set","defaultRowDeserializer","reduce","result","col","name","get","generateEmptyKeyedItems","start","end","i","getSize","table","isClosed","size","padFirstAndLastRow","firstRow","viewportSize","padding","tableSize","lastRow","min","max","first","last"],"sources":["../src/ViewportDataUtils.ts"],"sourcesContent":["import type { Key } from 'react';\nimport clamp from 'lodash.clamp';\nimport type { Column, Row, Table, TreeTable } from '@deephaven/jsapi-types';\nimport Log from '@deephaven/log';\nimport type { KeyedItem } from '@deephaven/utils';\n\nexport type OnTableUpdatedEvent = CustomEvent<{\n offset: number;\n columns: Column[];\n rows: ViewportRow[];\n}>;\n\nexport type RowDeserializer<T> = (row: ViewportRow, columns: Column[]) => T;\n\nexport type ViewportRow = Row & { offsetInSnapshot: number };\n\nconst log = Log.module('ViewportDataUtils');\n\n/**\n * Create a unique string key for a row based on its ordinal position in its\n * source table. This is calculated based on it's offset in the viewport\n * (row.offsetInSnapshot) + the offset of the snapshot.\n * @param row Row from a Table update event.\n * @param offset Offset of the current viewport.\n * @returns Unique string key for the ordinal position of the given row.\n */\nexport function createKeyFromOffsetRow(\n row: ViewportRow,\n offset: number\n): string {\n return String(row.offsetInSnapshot + offset);\n}\n\n/**\n * Creates a handler function for a `dh.Table.EVENT_UPDATED` event. Rows that\n * get passed to the handler will be bulk updated in the given `viewportData`\n * object based on their derived item keys.\n * @param viewportData State object for managing a list of KeyedItem data.\n * @param deserializeRow Converts a DH Row to an item object.\n * @returns Handler function for a `dh.Table.EVENT_UPDATED` event.\n */\nexport function createOnTableUpdatedHandler<T>(\n { bulkUpdate }: { bulkUpdate: (itemMap: Map<Key, KeyedItem<T>>) => void },\n deserializeRow: RowDeserializer<T>\n): (event: OnTableUpdatedEvent) => void {\n /**\n * Handler for a `dh.Table.EVENT_UPDATED` event.\n */\n return function onTableUpdated(event: OnTableUpdatedEvent) {\n const { columns, offset, rows } = event.detail;\n\n log.debug('table updated', event.detail);\n\n const updateKeyMap = new Map<Key, KeyedItem<T>>();\n\n rows.forEach(row => {\n const item = deserializeRow(row, columns);\n const key = createKeyFromOffsetRow(row, offset);\n updateKeyMap.set(key, { key, item });\n });\n\n log.debug('update keys', updateKeyMap);\n\n bulkUpdate(updateKeyMap);\n };\n}\n\n/**\n * Maps a Row to a key / value object. Keys are mapped ver batim from column\n * names.\n * @param row Row to map to an item.\n * @param columns Columns to map.\n * @returns A key / value object for the row.\n */\nexport function defaultRowDeserializer<T>(\n row: ViewportRow,\n columns: Column[]\n): T {\n return columns.reduce((result, col) => {\n // eslint-disable-next-line no-param-reassign\n result[col.name as keyof T] = row.get(col);\n return result;\n }, {} as T);\n}\n\n/**\n * For windowing to work, the underlying list needs to maintain a KeyedItem for\n * each row in the backing table (even if these rows haven't been loaded yet).\n * This is needed internally by react-spectrum so it can calculate the content\n * area size. This generator can create a range of empty `KeyedItem` objects.\n * @param start The starting index to generate\n * @param end The ending index to generate\n */\nexport function* generateEmptyKeyedItems<T>(\n start: number,\n end: number\n): Generator<KeyedItem<T>, void, unknown> {\n // eslint-disable-next-line no-plusplus\n for (let i = start; i <= end; ++i) {\n yield { key: String(i) };\n }\n}\n\n/**\n * Check a Table to see if it is closed before checking its size property. This\n * is important because calling Table.size on a closed table throws an error. If\n * the table is null or closed, return zero. Otherwise, return the current size.\n * @param table The table to check for its size.\n * @returns The size of the table or zero if the table is null or closed.\n */\nexport function getSize(table?: Table | TreeTable | null): number {\n return table == null || isClosed(table) ? 0 : table.size;\n}\n\n/**\n * Check if a given table is closed. Tree tables don't have an `isClosed` prop,\n * so will always return false.\n * @param table The table to check if it is closed.\n */\nexport function isClosed(table: Table | TreeTable): boolean {\n if ('isClosed' in table) {\n return table.isClosed;\n }\n\n return false;\n}\n\n/**\n * Determine the first and last row index for a viewport + extra leading and\n * trailing padding. Values will be \"clamped\" to stay within the table size.\n * @param firstRow Starting row index for the viewport.\n * @param viewportSize Size of the viewport.\n * @param padding Extra rows to add to the viewport. Will be used for leading\n * and trailing rows.\n * @param tableSize Total table size.\n * @returns Tuple containing indices for the first and last row.\n */\nexport function padFirstAndLastRow(\n firstRow: number,\n viewportSize: number,\n padding: number,\n tableSize: number\n): [number, number] {\n const lastRow = firstRow + viewportSize - 1;\n const [min, max] = [0, tableSize - 1];\n\n const first = clamp(firstRow - padding, min, max);\n const last = clamp(lastRow + padding, min, max);\n\n return [first, last];\n}\n"],"mappings":"AACA,OAAOA,KAAK,MAAM,cAAc;AAEhC,OAAOC,GAAG,MAAM,gBAAgB;AAahC,IAAMC,GAAG,GAAGD,GAAG,CAACE,MAAM,CAAC,mBAAmB,CAAC;;AAE3C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,SAASC,
|
|
1
|
+
{"version":3,"file":"ViewportDataUtils.js","names":["clamp","Log","log","module","createKeyFromOffsetRow","row","offset","String","offsetInSnapshot","createOnTableUpdatedHandler","_ref","deserializeRow","bulkUpdate","onTableUpdated","event","columns","rows","detail","debug","updateKeyMap","Map","forEach","item","key","set","defaultRowDeserializer","reduce","result","col","name","get","generateEmptyKeyedItems","start","end","i","getSize","table","isClosed","size","padFirstAndLastRow","firstRow","viewportSize","padding","tableSize","lastRow","min","max","first","last"],"sources":["../src/ViewportDataUtils.ts"],"sourcesContent":["import type { Key } from 'react';\nimport clamp from 'lodash.clamp';\nimport type { Column, Row, Table, TreeTable } from '@deephaven/jsapi-types';\nimport Log from '@deephaven/log';\nimport type { KeyedItem } from '@deephaven/utils';\n\nexport type OnTableUpdatedEvent = CustomEvent<{\n offset: number;\n columns: Column[];\n rows: ViewportRow[];\n}>;\n\nexport type RowDeserializer<T> = (row: ViewportRow, columns: Column[]) => T;\n\nexport type ViewportRow = Row & { offsetInSnapshot: number };\n\nconst log = Log.module('ViewportDataUtils');\n\n/**\n * Create a unique string key for a row based on its ordinal position in its\n * source table. This is calculated based on it's offset in the viewport\n * (row.offsetInSnapshot) + the offset of the snapshot.\n * @param row Row from a Table update event.\n * @param offset Offset of the current viewport.\n * @returns Unique string key for the ordinal position of the given row.\n */\nexport function createKeyFromOffsetRow(\n row: ViewportRow,\n offset: number\n): string {\n return String(row.offsetInSnapshot + offset);\n}\n\n/**\n * Creates a handler function for a `dh.Table.EVENT_UPDATED` event. Rows that\n * get passed to the handler will be bulk updated in the given `viewportData`\n * object based on their derived item keys.\n * @param viewportData State object for managing a list of KeyedItem data.\n * @param deserializeRow Converts a DH Row to an item object.\n * @returns Handler function for a `dh.Table.EVENT_UPDATED` event.\n */\nexport function createOnTableUpdatedHandler<T>(\n { bulkUpdate }: { bulkUpdate: (itemMap: Map<Key, KeyedItem<T>>) => void },\n deserializeRow: RowDeserializer<T>\n): (event: OnTableUpdatedEvent) => void {\n /**\n * Handler for a `dh.Table.EVENT_UPDATED` event.\n */\n return function onTableUpdated(event: OnTableUpdatedEvent) {\n const { columns, offset, rows } = event.detail;\n\n log.debug('table updated', event.detail);\n\n const updateKeyMap = new Map<Key, KeyedItem<T>>();\n\n rows.forEach(row => {\n const item = deserializeRow(row, columns);\n const key = createKeyFromOffsetRow(row, offset);\n updateKeyMap.set(key, { key, item });\n });\n\n log.debug('update keys', updateKeyMap);\n\n bulkUpdate(updateKeyMap);\n };\n}\n\n/**\n * Maps a Row to a key / value object. Keys are mapped ver batim from column\n * names.\n * @param row Row to map to an item.\n * @param columns Columns to map.\n * @returns A key / value object for the row.\n */\nexport function defaultRowDeserializer<T>(\n row: ViewportRow,\n columns: Column[]\n): T {\n return columns.reduce((result, col) => {\n // eslint-disable-next-line no-param-reassign\n result[col.name as keyof T] = row.get(col);\n return result;\n }, {} as T);\n}\n\n/**\n * For windowing to work, the underlying list needs to maintain a KeyedItem for\n * each row in the backing table (even if these rows haven't been loaded yet).\n * This is needed internally by react-spectrum so it can calculate the content\n * area size. This generator can create a range of empty `KeyedItem` objects.\n * @param start The starting index to generate\n * @param end The ending index to generate\n */\nexport function* generateEmptyKeyedItems<T>(\n start: number,\n end: number\n): Generator<KeyedItem<T>, void, unknown> {\n // eslint-disable-next-line no-plusplus\n for (let i = start; i <= end; ++i) {\n yield { key: String(i) };\n }\n}\n\n/**\n * Check a Table to see if it is closed before checking its size property. This\n * is important because calling Table.size on a closed table throws an error. If\n * the table is null or closed, return zero. Otherwise, return the current size.\n * @param table The table to check for its size.\n * @returns The size of the table or zero if the table is null or closed.\n */\nexport function getSize(table?: Table | TreeTable | null): number {\n return table == null || isClosed(table) ? 0 : table.size;\n}\n\n/**\n * Check if a given table is closed. Tree tables don't have an `isClosed` prop,\n * so will always return false.\n * @param table The table to check if it is closed.\n */\nexport function isClosed(table: Table | TreeTable): boolean {\n if ('isClosed' in table) {\n return table.isClosed;\n }\n\n return false;\n}\n\n/**\n * Determine the first and last row index for a viewport + extra leading and\n * trailing padding. Values will be \"clamped\" to stay within the table size.\n * @param firstRow Starting row index for the viewport.\n * @param viewportSize Size of the viewport.\n * @param padding Extra rows to add to the viewport. Will be used for leading\n * and trailing rows.\n * @param tableSize Total table size.\n * @returns Tuple containing indices for the first and last row.\n */\nexport function padFirstAndLastRow(\n firstRow: number,\n viewportSize: number,\n padding: number,\n tableSize: number\n): [number, number] {\n const lastRow = firstRow + viewportSize - 1;\n const [min, max] = [0, tableSize - 1];\n\n const first = clamp(firstRow - padding, min, max);\n const last = clamp(lastRow + padding, min, max);\n\n return [first, last];\n}\n"],"mappings":"AACA,OAAOA,KAAK,MAAM,cAAc;AAEhC,OAAOC,GAAG,MAAM,gBAAgB;AAahC,IAAMC,GAAG,GAAGD,GAAG,CAACE,MAAM,CAAC,mBAAmB,CAAC;;AAE3C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,SAASC,sBAAsBA,CACpCC,GAAgB,EAChBC,MAAc,EACN;EACR,OAAOC,MAAM,CAACF,GAAG,CAACG,gBAAgB,GAAGF,MAAM,CAAC;AAC9C;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,SAASG,2BAA2BA,CAAAC,IAAA,EAEzCC,cAAkC,EACI;EAAA,IAFtC;IAAEC;EAAsE,CAAC,GAAAF,IAAA;EAGzE;AACF;AACA;EACE,OAAO,SAASG,cAAcA,CAACC,KAA0B,EAAE;IACzD,IAAM;MAAEC,OAAO;MAAET,MAAM;MAAEU;IAAK,CAAC,GAAGF,KAAK,CAACG,MAAM;IAE9Cf,GAAG,CAACgB,KAAK,CAAC,eAAe,EAAEJ,KAAK,CAACG,MAAM,CAAC;IAExC,IAAME,YAAY,GAAG,IAAIC,GAAG,CAAoB,CAAC;IAEjDJ,IAAI,CAACK,OAAO,CAAChB,GAAG,IAAI;MAClB,IAAMiB,IAAI,GAAGX,cAAc,CAACN,GAAG,EAAEU,OAAO,CAAC;MACzC,IAAMQ,GAAG,GAAGnB,sBAAsB,CAACC,GAAG,EAAEC,MAAM,CAAC;MAC/Ca,YAAY,CAACK,GAAG,CAACD,GAAG,EAAE;QAAEA,GAAG;QAAED;MAAK,CAAC,CAAC;IACtC,CAAC,CAAC;IAEFpB,GAAG,CAACgB,KAAK,CAAC,aAAa,EAAEC,YAAY,CAAC;IAEtCP,UAAU,CAACO,YAAY,CAAC;EAC1B,CAAC;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,SAASM,sBAAsBA,CACpCpB,GAAgB,EAChBU,OAAiB,EACd;EACH,OAAOA,OAAO,CAACW,MAAM,CAAC,CAACC,MAAM,EAAEC,GAAG,KAAK;IACrC;IACAD,MAAM,CAACC,GAAG,CAACC,IAAI,CAAY,GAAGxB,GAAG,CAACyB,GAAG,CAACF,GAAG,CAAC;IAC1C,OAAOD,MAAM;EACf,CAAC,EAAE,CAAC,CAAM,CAAC;AACb;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,UAAUI,uBAAuBA,CACtCC,KAAa,EACbC,GAAW,EAC6B;EACxC;EACA,KAAK,IAAIC,CAAC,GAAGF,KAAK,EAAEE,CAAC,IAAID,GAAG,EAAE,EAAEC,CAAC,EAAE;IACjC,MAAM;MAAEX,GAAG,EAAEhB,MAAM,CAAC2B,CAAC;IAAE,CAAC;EAC1B;AACF;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,SAASC,OAAOA,CAACC,KAAgC,EAAU;EAChE,OAAOA,KAAK,IAAI,IAAI,IAAIC,QAAQ,CAACD,KAAK,CAAC,GAAG,CAAC,GAAGA,KAAK,CAACE,IAAI;AAC1D;;AAEA;AACA;AACA;AACA;AACA;AACA,OAAO,SAASD,QAAQA,CAACD,KAAwB,EAAW;EAC1D,IAAI,UAAU,IAAIA,KAAK,EAAE;IACvB,OAAOA,KAAK,CAACC,QAAQ;EACvB;EAEA,OAAO,KAAK;AACd;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,SAASE,kBAAkBA,CAChCC,QAAgB,EAChBC,YAAoB,EACpBC,OAAe,EACfC,SAAiB,EACC;EAClB,IAAMC,OAAO,GAAGJ,QAAQ,GAAGC,YAAY,GAAG,CAAC;EAC3C,IAAM,CAACI,GAAG,EAAEC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAEH,SAAS,GAAG,CAAC,CAAC;EAErC,IAAMI,KAAK,GAAG/C,KAAK,CAACwC,QAAQ,GAAGE,OAAO,EAAEG,GAAG,EAAEC,GAAG,CAAC;EACjD,IAAME,IAAI,GAAGhD,KAAK,CAAC4C,OAAO,GAAGF,OAAO,EAAEG,GAAG,EAAEC,GAAG,CAAC;EAE/C,OAAO,CAACC,KAAK,EAAEC,IAAI,CAAC;AACtB"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BooleanColumnFormatter.js","names":["TableColumnFormatter","BooleanColumnFormatter","format","value"],"sources":["../../src/formatters/BooleanColumnFormatter.ts"],"sourcesContent":["/* eslint class-methods-use-this: \"off\" */\n/* eslint no-unused-vars: \"off\" */\nimport TableColumnFormatter from './TableColumnFormatter';\n\n/** Column formatter for booleans */\nclass BooleanColumnFormatter extends TableColumnFormatter<boolean | number> {\n format(value: boolean | number): string {\n switch (value) {\n case 1:\n case true:\n return 'true';\n case 0:\n case false:\n return 'false';\n default:\n return '';\n }\n }\n}\n\nexport default BooleanColumnFormatter;\n"],"mappings":"AAAA;AACA;AAAA,OACOA,oBAAoB;AAE3B;AACA,MAAMC,sBAAsB,SAASD,oBAAoB,CAAmB;EAC1EE,
|
|
1
|
+
{"version":3,"file":"BooleanColumnFormatter.js","names":["TableColumnFormatter","BooleanColumnFormatter","format","value"],"sources":["../../src/formatters/BooleanColumnFormatter.ts"],"sourcesContent":["/* eslint class-methods-use-this: \"off\" */\n/* eslint no-unused-vars: \"off\" */\nimport TableColumnFormatter from './TableColumnFormatter';\n\n/** Column formatter for booleans */\nclass BooleanColumnFormatter extends TableColumnFormatter<boolean | number> {\n format(value: boolean | number): string {\n switch (value) {\n case 1:\n case true:\n return 'true';\n case 0:\n case false:\n return 'false';\n default:\n return '';\n }\n }\n}\n\nexport default BooleanColumnFormatter;\n"],"mappings":"AAAA;AACA;AAAA,OACOA,oBAAoB;AAE3B;AACA,MAAMC,sBAAsB,SAASD,oBAAoB,CAAmB;EAC1EE,MAAMA,CAACC,KAAuB,EAAU;IACtC,QAAQA,KAAK;MACX,KAAK,CAAC;MACN,KAAK,IAAI;QACP,OAAO,MAAM;MACf,KAAK,CAAC;MACN,KAAK,KAAK;QACR,OAAO,OAAO;MAChB;QACE,OAAO,EAAE;IACb;EACF;AACF;AAEA,eAAeF,sBAAsB"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CharColumnFormatter.js","names":["TableColumnFormatter","CharColumnFormatter","format","value","String","fromCharCode"],"sources":["../../src/formatters/CharColumnFormatter.ts"],"sourcesContent":["/* eslint class-methods-use-this: \"off\" */\n/* eslint no-unused-vars: \"off\" */\nimport TableColumnFormatter from './TableColumnFormatter';\n\n/** Column formatter for chars */\nclass CharColumnFormatter extends TableColumnFormatter<number> {\n format(value: number): string {\n return String.fromCharCode(value);\n }\n}\n\nexport default CharColumnFormatter;\n"],"mappings":"AAAA;AACA;AAAA,OACOA,oBAAoB;AAE3B;AACA,MAAMC,mBAAmB,SAASD,oBAAoB,CAAS;EAC7DE,
|
|
1
|
+
{"version":3,"file":"CharColumnFormatter.js","names":["TableColumnFormatter","CharColumnFormatter","format","value","String","fromCharCode"],"sources":["../../src/formatters/CharColumnFormatter.ts"],"sourcesContent":["/* eslint class-methods-use-this: \"off\" */\n/* eslint no-unused-vars: \"off\" */\nimport TableColumnFormatter from './TableColumnFormatter';\n\n/** Column formatter for chars */\nclass CharColumnFormatter extends TableColumnFormatter<number> {\n format(value: number): string {\n return String.fromCharCode(value);\n }\n}\n\nexport default CharColumnFormatter;\n"],"mappings":"AAAA;AACA;AAAA,OACOA,oBAAoB;AAE3B;AACA,MAAMC,mBAAmB,SAASD,oBAAoB,CAAS;EAC7DE,MAAMA,CAACC,KAAa,EAAU;IAC5B,OAAOC,MAAM,CAACC,YAAY,CAACF,KAAK,CAAC;EACnC;AACF;AAEA,eAAeF,mBAAmB"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DateTimeColumnFormatter.js","names":["Log","TableColumnFormatter","log","module","DateTimeColumnFormatter","isValid","dh","format","i18n","DateTimeFormat","formatString","Date","e","makeFormat","label","type","TYPE_CONTEXT_PRESET","isSameFormat","formatA","formatB","makeGlobalFormatStringMap","showTimeZone","showTSeparator","separator","tz","Map","getGlobalFormats","formatStringMap","keys","makeFormatStringMap","undefined","getFormats","constructor","timeZone","timeZoneParam","defaultDateTimeFormatString","DEFAULT_DATETIME_FORMAT_STRING","DEFAULT_TIME_ZONE_ID","dhTimeZone","TimeZone","getTimeZone","error","getEffectiveFormatString","baseFormatString","get","value"],"sources":["../../src/formatters/DateTimeColumnFormatter.ts"],"sourcesContent":["/* eslint class-methods-use-this: \"off\" */\nimport type {\n dh as DhType,\n DateWrapper,\n TimeZone,\n} from '@deephaven/jsapi-types';\nimport Log from '@deephaven/log';\nimport TableColumnFormatter, {\n TableColumnFormat,\n} from './TableColumnFormatter';\n\nconst log = Log.module('DateTimeColumnFormatter');\n\nexport type DateTimeColumnFormatterOptions = {\n // Time zone\n timeZone?: string;\n\n // Show time zone in DateTime values\n showTimeZone?: boolean;\n\n // Show 'T' separator in DateTime values\n showTSeparator?: boolean;\n\n // DateTime format to use if columnFormats for DateTime isn't set\n defaultDateTimeFormatString?: string;\n};\n\nexport class DateTimeColumnFormatter extends TableColumnFormatter<\n Date | DateWrapper | number\n> {\n /**\n * Validates format object\n * @param dh JSAPI instance\n * @param format Format object\n * @returns true for valid object\n */\n static isValid(\n dh: DhType,\n format: Pick<TableColumnFormat, 'formatString'>\n ): boolean {\n try {\n dh.i18n.DateTimeFormat.format(format.formatString, new Date());\n return true;\n } catch (e) {\n return false;\n }\n }\n\n static makeFormat(\n label: string,\n formatString: string,\n type = TableColumnFormatter.TYPE_CONTEXT_PRESET\n ): TableColumnFormat {\n return {\n label,\n formatString,\n type,\n };\n }\n\n /**\n * Check if the given formats match\n * @param formatA format object to check\n * @param formatB format object to check\n * @returns True if the formats match\n */\n static isSameFormat(\n formatA: TableColumnFormat | null,\n formatB: TableColumnFormat | null\n ): boolean {\n return (\n formatA === formatB ||\n (formatA !== null &&\n formatB !== null &&\n formatA.type === formatB.type &&\n formatA.formatString === formatB.formatString)\n );\n }\n\n static DEFAULT_DATETIME_FORMAT_STRING = 'yyyy-MM-dd HH:mm:ss.SSS';\n\n static DEFAULT_TIME_ZONE_ID = 'America/New_York';\n\n static makeGlobalFormatStringMap(\n showTimeZone: boolean,\n showTSeparator: boolean\n ): Map<string, string> {\n const separator = showTSeparator ? `'T'` : ' ';\n const tz = showTimeZone ? ' z' : '';\n return new Map([\n ['yyyy-MM-dd HH:mm:ss', `yyyy-MM-dd${separator}HH:mm:ss${tz}`],\n ['yyyy-MM-dd HH:mm:ss.SSS', `yyyy-MM-dd${separator}HH:mm:ss.SSS${tz}`],\n [\n 'yyyy-MM-dd HH:mm:ss.SSSSSSSSS',\n `yyyy-MM-dd${separator}HH:mm:ss.SSSSSSSSS${tz}`,\n ],\n ]);\n }\n\n static getGlobalFormats(\n showTimeZone: boolean,\n showTSeparator: boolean\n ): string[] {\n const formatStringMap = DateTimeColumnFormatter.makeGlobalFormatStringMap(\n showTimeZone,\n showTSeparator\n );\n return [...formatStringMap.keys()];\n }\n\n static makeFormatStringMap(\n showTimeZone?: boolean,\n showTSeparator?: boolean\n ): Map<string, string> {\n const separator =\n showTSeparator !== undefined && showTSeparator ? `'T'` : ' ';\n const tz = showTimeZone !== undefined && showTimeZone ? ' z' : '';\n return new Map([\n ['yyyy-MM-dd', `yyyy-MM-dd${tz}`],\n ['MM-dd-yyyy', `MM-dd-yyyy${tz}`],\n ['HH:mm:ss', `HH:mm:ss${tz}`],\n ['HH:mm:ss.SSS', `HH:mm:ss.SSS${tz}`],\n ['HH:mm:ss.SSSSSSSSS', `HH:mm:ss.SSSSSSSSS${tz}`],\n ['yyyy-MM-dd HH:mm:ss', `yyyy-MM-dd${separator}HH:mm:ss${tz}`],\n ['yyyy-MM-dd HH:mm:ss.SSS', `yyyy-MM-dd${separator}HH:mm:ss.SSS${tz}`],\n [\n 'yyyy-MM-dd HH:mm:ss.SSSSSSSSS',\n `yyyy-MM-dd${separator}HH:mm:ss.SSSSSSSSS${tz}`,\n ],\n ]);\n }\n\n static getFormats(\n showTimeZone?: boolean,\n showTSeparator?: boolean\n ): string[] {\n const formatStringMap = DateTimeColumnFormatter.makeFormatStringMap(\n showTimeZone,\n showTSeparator\n );\n return [...formatStringMap.keys()];\n }\n\n dh: DhType;\n\n dhTimeZone: TimeZone;\n\n defaultDateTimeFormatString: string;\n\n showTimeZone: boolean;\n\n showTSeparator: boolean;\n\n formatStringMap: Map<string, string>;\n\n constructor(\n dh: DhType,\n {\n timeZone: timeZoneParam = '',\n showTimeZone = true,\n showTSeparator = false,\n defaultDateTimeFormatString = DateTimeColumnFormatter.DEFAULT_DATETIME_FORMAT_STRING,\n }: DateTimeColumnFormatterOptions = {}\n ) {\n super();\n\n const timeZone =\n timeZoneParam || DateTimeColumnFormatter.DEFAULT_TIME_ZONE_ID;\n\n try {\n this.dhTimeZone = dh.i18n.TimeZone.getTimeZone(timeZone);\n } catch (e) {\n log.error('Unsupported time zone id', timeZone);\n this.dhTimeZone = dh.i18n.TimeZone.getTimeZone(\n DateTimeColumnFormatter.DEFAULT_TIME_ZONE_ID\n );\n }\n this.dh = dh;\n this.defaultDateTimeFormatString = defaultDateTimeFormatString;\n this.showTimeZone = showTimeZone;\n this.showTSeparator = showTSeparator;\n this.formatStringMap = DateTimeColumnFormatter.makeFormatStringMap(\n showTimeZone,\n showTSeparator\n );\n }\n\n getEffectiveFormatString(baseFormatString: string): string {\n return this.formatStringMap.get(baseFormatString) ?? baseFormatString;\n }\n\n format(\n value: Date | DateWrapper | number,\n format: Partial<TableColumnFormat> = {}\n ): string {\n const baseFormatString =\n format.formatString != null && format.formatString !== ''\n ? format.formatString\n : this.defaultDateTimeFormatString;\n const formatString = this.getEffectiveFormatString(baseFormatString);\n try {\n return this.dh.i18n.DateTimeFormat.format(\n formatString,\n value,\n this.dhTimeZone\n );\n } catch (e) {\n log.error('Invalid format arguments');\n }\n return '';\n }\n}\n\nexport default DateTimeColumnFormatter;\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"DateTimeColumnFormatter.js","names":["Log","TableColumnFormatter","log","module","DateTimeColumnFormatter","isValid","dh","format","i18n","DateTimeFormat","formatString","Date","e","makeFormat","label","type","arguments","length","undefined","TYPE_CONTEXT_PRESET","isSameFormat","formatA","formatB","makeGlobalFormatStringMap","showTimeZone","showTSeparator","separator","tz","Map","concat","getGlobalFormats","formatStringMap","keys","makeFormatStringMap","getFormats","constructor","timeZone","timeZoneParam","defaultDateTimeFormatString","DEFAULT_DATETIME_FORMAT_STRING","_defineProperty","DEFAULT_TIME_ZONE_ID","dhTimeZone","TimeZone","getTimeZone","error","getEffectiveFormatString","baseFormatString","_this$formatStringMap","get","value"],"sources":["../../src/formatters/DateTimeColumnFormatter.ts"],"sourcesContent":["/* eslint class-methods-use-this: \"off\" */\nimport type {\n dh as DhType,\n DateWrapper,\n TimeZone,\n} from '@deephaven/jsapi-types';\nimport Log from '@deephaven/log';\nimport TableColumnFormatter, {\n TableColumnFormat,\n} from './TableColumnFormatter';\n\nconst log = Log.module('DateTimeColumnFormatter');\n\nexport type DateTimeColumnFormatterOptions = {\n // Time zone\n timeZone?: string;\n\n // Show time zone in DateTime values\n showTimeZone?: boolean;\n\n // Show 'T' separator in DateTime values\n showTSeparator?: boolean;\n\n // DateTime format to use if columnFormats for DateTime isn't set\n defaultDateTimeFormatString?: string;\n};\n\nexport class DateTimeColumnFormatter extends TableColumnFormatter<\n Date | DateWrapper | number\n> {\n /**\n * Validates format object\n * @param dh JSAPI instance\n * @param format Format object\n * @returns true for valid object\n */\n static isValid(\n dh: DhType,\n format: Pick<TableColumnFormat, 'formatString'>\n ): boolean {\n try {\n dh.i18n.DateTimeFormat.format(format.formatString, new Date());\n return true;\n } catch (e) {\n return false;\n }\n }\n\n static makeFormat(\n label: string,\n formatString: string,\n type = TableColumnFormatter.TYPE_CONTEXT_PRESET\n ): TableColumnFormat {\n return {\n label,\n formatString,\n type,\n };\n }\n\n /**\n * Check if the given formats match\n * @param formatA format object to check\n * @param formatB format object to check\n * @returns True if the formats match\n */\n static isSameFormat(\n formatA: TableColumnFormat | null,\n formatB: TableColumnFormat | null\n ): boolean {\n return (\n formatA === formatB ||\n (formatA !== null &&\n formatB !== null &&\n formatA.type === formatB.type &&\n formatA.formatString === formatB.formatString)\n );\n }\n\n static DEFAULT_DATETIME_FORMAT_STRING = 'yyyy-MM-dd HH:mm:ss.SSS';\n\n static DEFAULT_TIME_ZONE_ID = 'America/New_York';\n\n static makeGlobalFormatStringMap(\n showTimeZone: boolean,\n showTSeparator: boolean\n ): Map<string, string> {\n const separator = showTSeparator ? `'T'` : ' ';\n const tz = showTimeZone ? ' z' : '';\n return new Map([\n ['yyyy-MM-dd HH:mm:ss', `yyyy-MM-dd${separator}HH:mm:ss${tz}`],\n ['yyyy-MM-dd HH:mm:ss.SSS', `yyyy-MM-dd${separator}HH:mm:ss.SSS${tz}`],\n [\n 'yyyy-MM-dd HH:mm:ss.SSSSSSSSS',\n `yyyy-MM-dd${separator}HH:mm:ss.SSSSSSSSS${tz}`,\n ],\n ]);\n }\n\n static getGlobalFormats(\n showTimeZone: boolean,\n showTSeparator: boolean\n ): string[] {\n const formatStringMap = DateTimeColumnFormatter.makeGlobalFormatStringMap(\n showTimeZone,\n showTSeparator\n );\n return [...formatStringMap.keys()];\n }\n\n static makeFormatStringMap(\n showTimeZone?: boolean,\n showTSeparator?: boolean\n ): Map<string, string> {\n const separator =\n showTSeparator !== undefined && showTSeparator ? `'T'` : ' ';\n const tz = showTimeZone !== undefined && showTimeZone ? ' z' : '';\n return new Map([\n ['yyyy-MM-dd', `yyyy-MM-dd${tz}`],\n ['MM-dd-yyyy', `MM-dd-yyyy${tz}`],\n ['HH:mm:ss', `HH:mm:ss${tz}`],\n ['HH:mm:ss.SSS', `HH:mm:ss.SSS${tz}`],\n ['HH:mm:ss.SSSSSSSSS', `HH:mm:ss.SSSSSSSSS${tz}`],\n ['yyyy-MM-dd HH:mm:ss', `yyyy-MM-dd${separator}HH:mm:ss${tz}`],\n ['yyyy-MM-dd HH:mm:ss.SSS', `yyyy-MM-dd${separator}HH:mm:ss.SSS${tz}`],\n [\n 'yyyy-MM-dd HH:mm:ss.SSSSSSSSS',\n `yyyy-MM-dd${separator}HH:mm:ss.SSSSSSSSS${tz}`,\n ],\n ]);\n }\n\n static getFormats(\n showTimeZone?: boolean,\n showTSeparator?: boolean\n ): string[] {\n const formatStringMap = DateTimeColumnFormatter.makeFormatStringMap(\n showTimeZone,\n showTSeparator\n );\n return [...formatStringMap.keys()];\n }\n\n dh: DhType;\n\n dhTimeZone: TimeZone;\n\n defaultDateTimeFormatString: string;\n\n showTimeZone: boolean;\n\n showTSeparator: boolean;\n\n formatStringMap: Map<string, string>;\n\n constructor(\n dh: DhType,\n {\n timeZone: timeZoneParam = '',\n showTimeZone = true,\n showTSeparator = false,\n defaultDateTimeFormatString = DateTimeColumnFormatter.DEFAULT_DATETIME_FORMAT_STRING,\n }: DateTimeColumnFormatterOptions = {}\n ) {\n super();\n\n const timeZone =\n timeZoneParam || DateTimeColumnFormatter.DEFAULT_TIME_ZONE_ID;\n\n try {\n this.dhTimeZone = dh.i18n.TimeZone.getTimeZone(timeZone);\n } catch (e) {\n log.error('Unsupported time zone id', timeZone);\n this.dhTimeZone = dh.i18n.TimeZone.getTimeZone(\n DateTimeColumnFormatter.DEFAULT_TIME_ZONE_ID\n );\n }\n this.dh = dh;\n this.defaultDateTimeFormatString = defaultDateTimeFormatString;\n this.showTimeZone = showTimeZone;\n this.showTSeparator = showTSeparator;\n this.formatStringMap = DateTimeColumnFormatter.makeFormatStringMap(\n showTimeZone,\n showTSeparator\n );\n }\n\n getEffectiveFormatString(baseFormatString: string): string {\n return this.formatStringMap.get(baseFormatString) ?? baseFormatString;\n }\n\n format(\n value: Date | DateWrapper | number,\n format: Partial<TableColumnFormat> = {}\n ): string {\n const baseFormatString =\n format.formatString != null && format.formatString !== ''\n ? format.formatString\n : this.defaultDateTimeFormatString;\n const formatString = this.getEffectiveFormatString(baseFormatString);\n try {\n return this.dh.i18n.DateTimeFormat.format(\n formatString,\n value,\n this.dhTimeZone\n );\n } catch (e) {\n log.error('Invalid format arguments');\n }\n return '';\n }\n}\n\nexport default DateTimeColumnFormatter;\n"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DecimalColumnFormatter.js","names":["Log","TableColumnFormatter","log","module","DecimalColumnFormatter","isValid","dh","format","i18n","NumberFormat","formatString","e","makeFormat","label","type","TYPE_CONTEXT_PRESET","multiplier","makePresetFormat","makeCustomFormat","TYPE_CONTEXT_CUSTOM","isSameFormat","formatA","formatB","constructor","defaultFormatString","DEFAULT_FORMAT_STRING","valueParam","value","error"],"sources":["../../src/formatters/DecimalColumnFormatter.ts"],"sourcesContent":["/* eslint class-methods-use-this: \"off\" */\nimport type { dh as DhType } from '@deephaven/jsapi-types';\nimport Log from '@deephaven/log';\nimport TableColumnFormatter, {\n TableColumnFormat,\n} from './TableColumnFormatter';\n\nconst log = Log.module('DecimalColumnFormatter');\n\nexport type DecimalColumnFormat = TableColumnFormat & {\n multiplier?: number | null;\n};\n\nexport type DecimalColumnFormatterOptions = {\n // Default format string to use. Defaults to DecimalColumnFormatter.DEFAULT_FORMAT_STRING\n defaultFormatString?: string;\n};\n\nexport class DecimalColumnFormatter extends TableColumnFormatter<number> {\n /**\n * Validates format object\n * @param dh JSAPI instance\n * @param format Format object\n * @returns true for valid object\n */\n static isValid(\n dh: DhType,\n format: Pick<TableColumnFormat, 'formatString'>\n ): boolean {\n try {\n dh.i18n.NumberFormat.format(format.formatString, 0);\n return true;\n } catch (e) {\n return false;\n }\n }\n\n /**\n * Create a DecimalColumnFormat object with the parameters specified\n * @param label Label for the format\n * @param formatString Format string for the format\n * @param multiplier Optional multiplier for the formatter\n * @param type Type of format created\n * @returns DecimalColumnFormat object\n */\n static makeFormat(\n label: string,\n formatString: string,\n type = TableColumnFormatter.TYPE_CONTEXT_PRESET,\n multiplier?: number\n ): DecimalColumnFormat {\n return {\n label,\n type,\n formatString,\n multiplier,\n };\n }\n\n /**\n * Convenient function to create a DecimalFormatObject with Preset type set\n * @param label Label for this format object\n * @param formatString Format string to use\n * @param multiplier Multiplier to use\n * @returns DecimalColumnFormat object\n */\n static makePresetFormat(\n label: string,\n formatString = '',\n multiplier?: number\n ): DecimalColumnFormat {\n return DecimalColumnFormatter.makeFormat(\n label,\n formatString,\n TableColumnFormatter.TYPE_CONTEXT_PRESET,\n multiplier\n );\n }\n\n /**\n * Convenient function to create a DecimalFormatObject with a default 'Custom Format' label and Custom type\n * @param formatString Format string to use\n * @param multiplier Multiplier to use\n * @returns DecimalColumnFormat object\n */\n static makeCustomFormat(\n formatString = '',\n multiplier?: number\n ): DecimalColumnFormat {\n return DecimalColumnFormatter.makeFormat(\n 'Custom Format',\n formatString,\n TableColumnFormatter.TYPE_CONTEXT_CUSTOM,\n multiplier\n );\n }\n\n static DEFAULT_FORMAT_STRING = '###,##0.0000';\n\n static FORMAT_PERCENT = DecimalColumnFormatter.makePresetFormat(\n 'Percent',\n '##0.00%'\n );\n\n static FORMAT_BASIS_POINTS = DecimalColumnFormatter.makePresetFormat(\n 'Basis Points',\n '###,##0 bp',\n 10000\n );\n\n static FORMAT_MILLIONS = DecimalColumnFormatter.makePresetFormat(\n 'Millions',\n '###,##0.000 mm',\n 0.000001\n );\n\n static FORMAT_SCIENTIFIC_NOTATION = DecimalColumnFormatter.makePresetFormat(\n 'Scientific Notation',\n '0.0000E0'\n );\n\n static FORMAT_ROUND = DecimalColumnFormatter.makePresetFormat(\n 'Round',\n '###,##0'\n );\n\n static FORMAT_ROUND_TWO_DECIMALS = DecimalColumnFormatter.makePresetFormat(\n '0.00',\n '###,##0.00'\n );\n\n static FORMAT_ROUND_FOUR_DECIMALS = DecimalColumnFormatter.makePresetFormat(\n '0.0000',\n '###,##0.0000'\n );\n\n /**\n * Check if the given formats match\n * @param formatA format object to check\n * @param formatB format object to check\n * @returns True if the formats match\n */\n static isSameFormat(\n formatA: DecimalColumnFormat | null,\n formatB: DecimalColumnFormat | null\n ): boolean {\n return (\n formatA === formatB ||\n (formatA != null &&\n formatB != null &&\n formatA.type === formatB.type &&\n formatA.formatString === formatB.formatString &&\n formatA.multiplier === formatB.multiplier)\n );\n }\n\n defaultFormatString: string;\n\n dh: DhType;\n\n constructor(\n dh: DhType,\n {\n defaultFormatString = DecimalColumnFormatter.DEFAULT_FORMAT_STRING,\n }: DecimalColumnFormatterOptions = {}\n ) {\n super();\n\n this.dh = dh;\n this.defaultFormatString = defaultFormatString;\n }\n\n /**\n * Format a value with the provided format object\n * @param valueParam Value to format\n * @param format Format object\n * @returns Formatted string\n */\n format(\n valueParam: number,\n format: Partial<DecimalColumnFormat> = {}\n ): string {\n const formatString =\n format.formatString != null && format.formatString !== ''\n ? format.formatString\n : this.defaultFormatString;\n const value =\n format.multiplier != null && format.multiplier !== 0\n ? valueParam * format.multiplier\n : valueParam;\n try {\n return this.dh.i18n.NumberFormat.format(formatString, value);\n } catch (e) {\n log.error('Invalid format arguments');\n }\n return '';\n }\n}\n\nexport default DecimalColumnFormatter;\n"],"mappings":";;;AAAA;;AAEA,OAAOA,GAAG,MAAM,gBAAgB;AAAC,OAC1BC,oBAAoB;AAI3B,IAAMC,GAAG,GAAGF,GAAG,CAACG,MAAM,CAAC,wBAAwB,CAAC;AAWhD,OAAO,MAAMC,sBAAsB,SAASH,oBAAoB,CAAS;EACvE;AACF;AACA;AACA;AACA;AACA;EACE,OAAOI,
|
|
1
|
+
{"version":3,"file":"DecimalColumnFormatter.js","names":["Log","TableColumnFormatter","log","module","DecimalColumnFormatter","isValid","dh","format","i18n","NumberFormat","formatString","e","makeFormat","label","type","arguments","length","undefined","TYPE_CONTEXT_PRESET","multiplier","makePresetFormat","makeCustomFormat","TYPE_CONTEXT_CUSTOM","isSameFormat","formatA","formatB","constructor","defaultFormatString","DEFAULT_FORMAT_STRING","_defineProperty","valueParam","value","error"],"sources":["../../src/formatters/DecimalColumnFormatter.ts"],"sourcesContent":["/* eslint class-methods-use-this: \"off\" */\nimport type { dh as DhType } from '@deephaven/jsapi-types';\nimport Log from '@deephaven/log';\nimport TableColumnFormatter, {\n TableColumnFormat,\n} from './TableColumnFormatter';\n\nconst log = Log.module('DecimalColumnFormatter');\n\nexport type DecimalColumnFormat = TableColumnFormat & {\n multiplier?: number | null;\n};\n\nexport type DecimalColumnFormatterOptions = {\n // Default format string to use. Defaults to DecimalColumnFormatter.DEFAULT_FORMAT_STRING\n defaultFormatString?: string;\n};\n\nexport class DecimalColumnFormatter extends TableColumnFormatter<number> {\n /**\n * Validates format object\n * @param dh JSAPI instance\n * @param format Format object\n * @returns true for valid object\n */\n static isValid(\n dh: DhType,\n format: Pick<TableColumnFormat, 'formatString'>\n ): boolean {\n try {\n dh.i18n.NumberFormat.format(format.formatString, 0);\n return true;\n } catch (e) {\n return false;\n }\n }\n\n /**\n * Create a DecimalColumnFormat object with the parameters specified\n * @param label Label for the format\n * @param formatString Format string for the format\n * @param multiplier Optional multiplier for the formatter\n * @param type Type of format created\n * @returns DecimalColumnFormat object\n */\n static makeFormat(\n label: string,\n formatString: string,\n type = TableColumnFormatter.TYPE_CONTEXT_PRESET,\n multiplier?: number\n ): DecimalColumnFormat {\n return {\n label,\n type,\n formatString,\n multiplier,\n };\n }\n\n /**\n * Convenient function to create a DecimalFormatObject with Preset type set\n * @param label Label for this format object\n * @param formatString Format string to use\n * @param multiplier Multiplier to use\n * @returns DecimalColumnFormat object\n */\n static makePresetFormat(\n label: string,\n formatString = '',\n multiplier?: number\n ): DecimalColumnFormat {\n return DecimalColumnFormatter.makeFormat(\n label,\n formatString,\n TableColumnFormatter.TYPE_CONTEXT_PRESET,\n multiplier\n );\n }\n\n /**\n * Convenient function to create a DecimalFormatObject with a default 'Custom Format' label and Custom type\n * @param formatString Format string to use\n * @param multiplier Multiplier to use\n * @returns DecimalColumnFormat object\n */\n static makeCustomFormat(\n formatString = '',\n multiplier?: number\n ): DecimalColumnFormat {\n return DecimalColumnFormatter.makeFormat(\n 'Custom Format',\n formatString,\n TableColumnFormatter.TYPE_CONTEXT_CUSTOM,\n multiplier\n );\n }\n\n static DEFAULT_FORMAT_STRING = '###,##0.0000';\n\n static FORMAT_PERCENT = DecimalColumnFormatter.makePresetFormat(\n 'Percent',\n '##0.00%'\n );\n\n static FORMAT_BASIS_POINTS = DecimalColumnFormatter.makePresetFormat(\n 'Basis Points',\n '###,##0 bp',\n 10000\n );\n\n static FORMAT_MILLIONS = DecimalColumnFormatter.makePresetFormat(\n 'Millions',\n '###,##0.000 mm',\n 0.000001\n );\n\n static FORMAT_SCIENTIFIC_NOTATION = DecimalColumnFormatter.makePresetFormat(\n 'Scientific Notation',\n '0.0000E0'\n );\n\n static FORMAT_ROUND = DecimalColumnFormatter.makePresetFormat(\n 'Round',\n '###,##0'\n );\n\n static FORMAT_ROUND_TWO_DECIMALS = DecimalColumnFormatter.makePresetFormat(\n '0.00',\n '###,##0.00'\n );\n\n static FORMAT_ROUND_FOUR_DECIMALS = DecimalColumnFormatter.makePresetFormat(\n '0.0000',\n '###,##0.0000'\n );\n\n /**\n * Check if the given formats match\n * @param formatA format object to check\n * @param formatB format object to check\n * @returns True if the formats match\n */\n static isSameFormat(\n formatA: DecimalColumnFormat | null,\n formatB: DecimalColumnFormat | null\n ): boolean {\n return (\n formatA === formatB ||\n (formatA != null &&\n formatB != null &&\n formatA.type === formatB.type &&\n formatA.formatString === formatB.formatString &&\n formatA.multiplier === formatB.multiplier)\n );\n }\n\n defaultFormatString: string;\n\n dh: DhType;\n\n constructor(\n dh: DhType,\n {\n defaultFormatString = DecimalColumnFormatter.DEFAULT_FORMAT_STRING,\n }: DecimalColumnFormatterOptions = {}\n ) {\n super();\n\n this.dh = dh;\n this.defaultFormatString = defaultFormatString;\n }\n\n /**\n * Format a value with the provided format object\n * @param valueParam Value to format\n * @param format Format object\n * @returns Formatted string\n */\n format(\n valueParam: number,\n format: Partial<DecimalColumnFormat> = {}\n ): string {\n const formatString =\n format.formatString != null && format.formatString !== ''\n ? format.formatString\n : this.defaultFormatString;\n const value =\n format.multiplier != null && format.multiplier !== 0\n ? valueParam * format.multiplier\n : valueParam;\n try {\n return this.dh.i18n.NumberFormat.format(formatString, value);\n } catch (e) {\n log.error('Invalid format arguments');\n }\n return '';\n }\n}\n\nexport default DecimalColumnFormatter;\n"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DefaultColumnFormatter.js","names":["TableColumnFormatter","DefaultColumnFormatter","format","value"],"sources":["../../src/formatters/DefaultColumnFormatter.ts"],"sourcesContent":["/* eslint class-methods-use-this: \"off\" */\n/* eslint no-unused-vars: \"off\" */\nimport TableColumnFormatter from './TableColumnFormatter';\n\nclass DefaultColumnFormatter extends TableColumnFormatter {\n format(value: unknown): string {\n return `${value}`;\n }\n}\n\nexport default DefaultColumnFormatter;\n"],"mappings":"AAAA;AACA;AAAA,OACOA,oBAAoB;AAE3B,MAAMC,sBAAsB,SAASD,oBAAoB,CAAC;EACxDE,
|
|
1
|
+
{"version":3,"file":"DefaultColumnFormatter.js","names":["TableColumnFormatter","DefaultColumnFormatter","format","value","concat"],"sources":["../../src/formatters/DefaultColumnFormatter.ts"],"sourcesContent":["/* eslint class-methods-use-this: \"off\" */\n/* eslint no-unused-vars: \"off\" */\nimport TableColumnFormatter from './TableColumnFormatter';\n\nclass DefaultColumnFormatter extends TableColumnFormatter {\n format(value: unknown): string {\n return `${value}`;\n }\n}\n\nexport default DefaultColumnFormatter;\n"],"mappings":"AAAA;AACA;AAAA,OACOA,oBAAoB;AAE3B,MAAMC,sBAAsB,SAASD,oBAAoB,CAAC;EACxDE,MAAMA,CAACC,KAAc,EAAU;IAC7B,UAAAC,MAAA,CAAUD,KAAK;EACjB;AACF;AAEA,eAAeF,sBAAsB"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"IntegerColumnFormatter.js","names":["Log","TableColumnFormatter","log","module","IntegerColumnFormatter","isValid","dh","format","i18n","NumberFormat","formatString","e","makeFormat","label","type","TYPE_CONTEXT_PRESET","multiplier","makePresetFormat","makeCustomFormat","TYPE_CONTEXT_CUSTOM","isSameFormat","formatA","formatB","constructor","defaultFormatString","DEFAULT_FORMAT_STRING","valueParam","value","error"],"sources":["../../src/formatters/IntegerColumnFormatter.ts"],"sourcesContent":["/* eslint class-methods-use-this: \"off\" */\nimport type { dh as DhType } from '@deephaven/jsapi-types';\nimport Log from '@deephaven/log';\nimport TableColumnFormatter, {\n TableColumnFormat,\n} from './TableColumnFormatter';\n\nconst log = Log.module('IntegerColumnFormatter');\n\nexport type IntegerColumnFormat = TableColumnFormat & {\n multiplier?: number | null;\n};\n\nexport type IntegerColumnFormatterOptions = {\n // Default format string to use. Defaults to IntegerColumnFormatter.DEFAULT_FORMAT_STRING\n defaultFormatString?: string;\n};\n\n/** Column formatter for integers/whole numbers */\nexport class IntegerColumnFormatter extends TableColumnFormatter<number> {\n /**\n * Validates format object\n * @param dh JSAPI instance\n * @param format Format object\n * @returns true for valid object\n */\n static isValid(\n dh: DhType,\n format: Pick<TableColumnFormat, 'formatString'>\n ): boolean {\n try {\n dh.i18n.NumberFormat.format(format.formatString, 0);\n return true;\n } catch (e) {\n return false;\n }\n }\n\n /**\n * Create an IntegerColumnFormat object with the parameters specified\n * @param label Label for the format\n * @param formatString Format string for the format\n * @param multiplier Optional multiplier for the formatter\n * @param type Type of format created\n * @returns IntegerColumnFormat object\n */\n static makeFormat(\n label: string,\n formatString: string,\n type = TableColumnFormatter.TYPE_CONTEXT_PRESET,\n multiplier?: number\n ): IntegerColumnFormat {\n return {\n label,\n type,\n formatString,\n multiplier,\n };\n }\n\n /**\n * Convenient function to create a IntegerFormatObject with Preset type set\n * @param label Label for this format object\n * @param formatString Format string to use\n * @param multiplier Multiplier to use\n * @returns IntegerColumnFormat object\n */\n static makePresetFormat(\n label: string,\n formatString = '',\n multiplier?: number\n ): IntegerColumnFormat {\n return IntegerColumnFormatter.makeFormat(\n label,\n formatString,\n TableColumnFormatter.TYPE_CONTEXT_PRESET,\n multiplier\n );\n }\n\n /**\n * Convenient function to create a IntegerFormatObject with a default 'Custom Format' label and Custom type\n * @param formatString Format string to use\n * @param multiplier Multiplier to use\n * @returns IntegerColumnFormat object\n */\n static makeCustomFormat(\n formatString = '',\n multiplier?: number\n ): IntegerColumnFormat {\n return IntegerColumnFormatter.makeFormat(\n 'Custom Format',\n formatString,\n TableColumnFormatter.TYPE_CONTEXT_CUSTOM,\n multiplier\n );\n }\n\n /**\n * Check if the given formats match\n * @param formatA format object to check\n * @param formatB format object to check\n * @returns True if the formats match\n */\n static isSameFormat(\n formatA: IntegerColumnFormat | null,\n formatB: IntegerColumnFormat | null\n ): boolean {\n return (\n formatA === formatB ||\n (formatA != null &&\n formatB != null &&\n formatA.type === formatB.type &&\n formatA.formatString === formatB.formatString &&\n formatA.multiplier === formatB.multiplier)\n );\n }\n\n static DEFAULT_FORMAT_STRING = '###,##0';\n\n static FORMAT_MILLIONS = IntegerColumnFormatter.makePresetFormat(\n 'Millions',\n '###,##0.000 mm',\n 0.000001\n );\n\n static FORMAT_SCIENTIFIC_NOTATION = IntegerColumnFormatter.makePresetFormat(\n 'Scientific Notation',\n '0.0000E0'\n );\n\n dh: DhType;\n\n defaultFormatString: string;\n\n constructor(\n dh: DhType,\n {\n defaultFormatString = IntegerColumnFormatter.DEFAULT_FORMAT_STRING,\n }: IntegerColumnFormatterOptions = {}\n ) {\n super();\n this.dh = dh;\n this.defaultFormatString = defaultFormatString;\n }\n\n /**\n * Format a value with the provided format object\n * @param valueParam Value to format\n * @param format Format object\n * @returns Formatted string\n */\n format(\n valueParam: number,\n format: Partial<IntegerColumnFormat> = {}\n ): string {\n const formatString =\n format.formatString != null && format.formatString !== ''\n ? format.formatString\n : this.defaultFormatString;\n const value =\n format.multiplier != null && format.multiplier !== 0\n ? valueParam * format.multiplier\n : valueParam;\n try {\n return this.dh.i18n.NumberFormat.format(formatString, value);\n } catch (e) {\n log.error('Invalid format arguments');\n }\n return '';\n }\n}\n\nexport default IntegerColumnFormatter;\n"],"mappings":";;;AAAA;;AAEA,OAAOA,GAAG,MAAM,gBAAgB;AAAC,OAC1BC,oBAAoB;AAI3B,IAAMC,GAAG,GAAGF,GAAG,CAACG,MAAM,CAAC,wBAAwB,CAAC;AAWhD;AACA,OAAO,MAAMC,sBAAsB,SAASH,oBAAoB,CAAS;EACvE;AACF;AACA;AACA;AACA;AACA;EACE,OAAOI,
|
|
1
|
+
{"version":3,"file":"IntegerColumnFormatter.js","names":["Log","TableColumnFormatter","log","module","IntegerColumnFormatter","isValid","dh","format","i18n","NumberFormat","formatString","e","makeFormat","label","type","arguments","length","undefined","TYPE_CONTEXT_PRESET","multiplier","makePresetFormat","makeCustomFormat","TYPE_CONTEXT_CUSTOM","isSameFormat","formatA","formatB","constructor","defaultFormatString","DEFAULT_FORMAT_STRING","_defineProperty","valueParam","value","error"],"sources":["../../src/formatters/IntegerColumnFormatter.ts"],"sourcesContent":["/* eslint class-methods-use-this: \"off\" */\nimport type { dh as DhType } from '@deephaven/jsapi-types';\nimport Log from '@deephaven/log';\nimport TableColumnFormatter, {\n TableColumnFormat,\n} from './TableColumnFormatter';\n\nconst log = Log.module('IntegerColumnFormatter');\n\nexport type IntegerColumnFormat = TableColumnFormat & {\n multiplier?: number | null;\n};\n\nexport type IntegerColumnFormatterOptions = {\n // Default format string to use. Defaults to IntegerColumnFormatter.DEFAULT_FORMAT_STRING\n defaultFormatString?: string;\n};\n\n/** Column formatter for integers/whole numbers */\nexport class IntegerColumnFormatter extends TableColumnFormatter<number> {\n /**\n * Validates format object\n * @param dh JSAPI instance\n * @param format Format object\n * @returns true for valid object\n */\n static isValid(\n dh: DhType,\n format: Pick<TableColumnFormat, 'formatString'>\n ): boolean {\n try {\n dh.i18n.NumberFormat.format(format.formatString, 0);\n return true;\n } catch (e) {\n return false;\n }\n }\n\n /**\n * Create an IntegerColumnFormat object with the parameters specified\n * @param label Label for the format\n * @param formatString Format string for the format\n * @param multiplier Optional multiplier for the formatter\n * @param type Type of format created\n * @returns IntegerColumnFormat object\n */\n static makeFormat(\n label: string,\n formatString: string,\n type = TableColumnFormatter.TYPE_CONTEXT_PRESET,\n multiplier?: number\n ): IntegerColumnFormat {\n return {\n label,\n type,\n formatString,\n multiplier,\n };\n }\n\n /**\n * Convenient function to create a IntegerFormatObject with Preset type set\n * @param label Label for this format object\n * @param formatString Format string to use\n * @param multiplier Multiplier to use\n * @returns IntegerColumnFormat object\n */\n static makePresetFormat(\n label: string,\n formatString = '',\n multiplier?: number\n ): IntegerColumnFormat {\n return IntegerColumnFormatter.makeFormat(\n label,\n formatString,\n TableColumnFormatter.TYPE_CONTEXT_PRESET,\n multiplier\n );\n }\n\n /**\n * Convenient function to create a IntegerFormatObject with a default 'Custom Format' label and Custom type\n * @param formatString Format string to use\n * @param multiplier Multiplier to use\n * @returns IntegerColumnFormat object\n */\n static makeCustomFormat(\n formatString = '',\n multiplier?: number\n ): IntegerColumnFormat {\n return IntegerColumnFormatter.makeFormat(\n 'Custom Format',\n formatString,\n TableColumnFormatter.TYPE_CONTEXT_CUSTOM,\n multiplier\n );\n }\n\n /**\n * Check if the given formats match\n * @param formatA format object to check\n * @param formatB format object to check\n * @returns True if the formats match\n */\n static isSameFormat(\n formatA: IntegerColumnFormat | null,\n formatB: IntegerColumnFormat | null\n ): boolean {\n return (\n formatA === formatB ||\n (formatA != null &&\n formatB != null &&\n formatA.type === formatB.type &&\n formatA.formatString === formatB.formatString &&\n formatA.multiplier === formatB.multiplier)\n );\n }\n\n static DEFAULT_FORMAT_STRING = '###,##0';\n\n static FORMAT_MILLIONS = IntegerColumnFormatter.makePresetFormat(\n 'Millions',\n '###,##0.000 mm',\n 0.000001\n );\n\n static FORMAT_SCIENTIFIC_NOTATION = IntegerColumnFormatter.makePresetFormat(\n 'Scientific Notation',\n '0.0000E0'\n );\n\n dh: DhType;\n\n defaultFormatString: string;\n\n constructor(\n dh: DhType,\n {\n defaultFormatString = IntegerColumnFormatter.DEFAULT_FORMAT_STRING,\n }: IntegerColumnFormatterOptions = {}\n ) {\n super();\n this.dh = dh;\n this.defaultFormatString = defaultFormatString;\n }\n\n /**\n * Format a value with the provided format object\n * @param valueParam Value to format\n * @param format Format object\n * @returns Formatted string\n */\n format(\n valueParam: number,\n format: Partial<IntegerColumnFormat> = {}\n ): string {\n const formatString =\n format.formatString != null && format.formatString !== ''\n ? format.formatString\n : this.defaultFormatString;\n const value =\n format.multiplier != null && format.multiplier !== 0\n ? valueParam * format.multiplier\n : valueParam;\n try {\n return this.dh.i18n.NumberFormat.format(formatString, value);\n } catch (e) {\n log.error('Invalid format arguments');\n }\n return '';\n }\n}\n\nexport default IntegerColumnFormatter;\n"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"StringColumnFormatter.js","names":["TableColumnFormatter","StringColumnFormatter","format","value"],"sources":["../../src/formatters/StringColumnFormatter.ts"],"sourcesContent":["/* eslint class-methods-use-this: \"off\" */\nimport TableColumnFormatter from './TableColumnFormatter';\n\n/** Column formatter for strings */\nexport class StringColumnFormatter extends TableColumnFormatter<string> {\n format(value: string): string {\n return value;\n }\n}\n\nexport default StringColumnFormatter;\n"],"mappings":"AAAA;AAAA,OACOA,oBAAoB;AAE3B;AACA,OAAO,MAAMC,qBAAqB,SAASD,oBAAoB,CAAS;EACtEE,
|
|
1
|
+
{"version":3,"file":"StringColumnFormatter.js","names":["TableColumnFormatter","StringColumnFormatter","format","value"],"sources":["../../src/formatters/StringColumnFormatter.ts"],"sourcesContent":["/* eslint class-methods-use-this: \"off\" */\nimport TableColumnFormatter from './TableColumnFormatter';\n\n/** Column formatter for strings */\nexport class StringColumnFormatter extends TableColumnFormatter<string> {\n format(value: string): string {\n return value;\n }\n}\n\nexport default StringColumnFormatter;\n"],"mappings":"AAAA;AAAA,OACOA,oBAAoB;AAE3B;AACA,OAAO,MAAMC,qBAAqB,SAASD,oBAAoB,CAAS;EACtEE,MAAMA,CAACC,KAAa,EAAU;IAC5B,OAAOA,KAAK;EACd;AACF;AAEA,eAAeF,qBAAqB"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TableColumnFormatter.js","names":["TableColumnFormatter","isValid","dh","format","isSameFormat","formatA","formatB","Error","makeFormat","label","formatString","type","value"],"sources":["../../src/formatters/TableColumnFormatter.ts"],"sourcesContent":["/* eslint class-methods-use-this: \"off\" */\n/**\n * Default column data formatter. Just interpolates the value as a string and returns.\n * Extend this class and register with TableUtils to make use of it.\n */\n\nimport type { dh as DhType } from '@deephaven/jsapi-types';\n\nexport type TableColumnFormatType =\n | 'type-global'\n | 'type-context-preset'\n | 'type-context-custom';\n\nexport type TableColumnFormat = {\n label: string;\n formatString: string;\n type: TableColumnFormatType;\n};\n\nexport class TableColumnFormatter<T = unknown> {\n static TYPE_GLOBAL: TableColumnFormatType = 'type-global';\n\n static TYPE_CONTEXT_PRESET: TableColumnFormatType = 'type-context-preset';\n\n static TYPE_CONTEXT_CUSTOM: TableColumnFormatType = 'type-context-custom';\n\n /**\n * Validates format object\n * @param dh JSAPI instance\n * @param format Format object\n * @returns true for valid object\n */\n static isValid(dh: DhType, format: TableColumnFormat): boolean {\n return true;\n }\n\n /**\n * Check if the given formats match\n * @param formatA format object to check\n * @param formatB format object to check\n * @returns True if the formats match\n */\n static isSameFormat(\n formatA: TableColumnFormat | null,\n formatB: TableColumnFormat | null\n ): boolean {\n throw new Error('isSameFormat not implemented');\n }\n\n /**\n * Create and return a Format object\n * @param label The label of the format object\n * @param formatString Format string to use for the format\n * @param type The type of column to use for this format\n * @returns A format object\n */\n static makeFormat(\n label: string,\n formatString: string,\n type: TableColumnFormatType\n ): TableColumnFormat {\n return { label, formatString, type };\n }\n\n /**\n * @param value The value to format\n * @param format Optional format object with value transformation options\n * @returns String the formatted text string of the value passed in.\n */\n format(value: T, format?: Partial<TableColumnFormat>): string {\n return '';\n }\n}\n\nexport default TableColumnFormatter;\n"],"mappings":";;;AAAA;AACA;AACA;AACA;AACA;;AAeA,OAAO,MAAMA,oBAAoB,CAAc;EAO7C;AACF;AACA;AACA;AACA;AACA;EACE,OAAOC,
|
|
1
|
+
{"version":3,"file":"TableColumnFormatter.js","names":["TableColumnFormatter","isValid","dh","format","isSameFormat","formatA","formatB","Error","makeFormat","label","formatString","type","value","_defineProperty"],"sources":["../../src/formatters/TableColumnFormatter.ts"],"sourcesContent":["/* eslint class-methods-use-this: \"off\" */\n/**\n * Default column data formatter. Just interpolates the value as a string and returns.\n * Extend this class and register with TableUtils to make use of it.\n */\n\nimport type { dh as DhType } from '@deephaven/jsapi-types';\n\nexport type TableColumnFormatType =\n | 'type-global'\n | 'type-context-preset'\n | 'type-context-custom';\n\nexport type TableColumnFormat = {\n label: string;\n formatString: string;\n type: TableColumnFormatType;\n};\n\nexport class TableColumnFormatter<T = unknown> {\n static TYPE_GLOBAL: TableColumnFormatType = 'type-global';\n\n static TYPE_CONTEXT_PRESET: TableColumnFormatType = 'type-context-preset';\n\n static TYPE_CONTEXT_CUSTOM: TableColumnFormatType = 'type-context-custom';\n\n /**\n * Validates format object\n * @param dh JSAPI instance\n * @param format Format object\n * @returns true for valid object\n */\n static isValid(dh: DhType, format: TableColumnFormat): boolean {\n return true;\n }\n\n /**\n * Check if the given formats match\n * @param formatA format object to check\n * @param formatB format object to check\n * @returns True if the formats match\n */\n static isSameFormat(\n formatA: TableColumnFormat | null,\n formatB: TableColumnFormat | null\n ): boolean {\n throw new Error('isSameFormat not implemented');\n }\n\n /**\n * Create and return a Format object\n * @param label The label of the format object\n * @param formatString Format string to use for the format\n * @param type The type of column to use for this format\n * @returns A format object\n */\n static makeFormat(\n label: string,\n formatString: string,\n type: TableColumnFormatType\n ): TableColumnFormat {\n return { label, formatString, type };\n }\n\n /**\n * @param value The value to format\n * @param format Optional format object with value transformation options\n * @returns String the formatted text string of the value passed in.\n */\n format(value: T, format?: Partial<TableColumnFormat>): string {\n return '';\n }\n}\n\nexport default TableColumnFormatter;\n"],"mappings":";;;AAAA;AACA;AACA;AACA;AACA;;AAeA,OAAO,MAAMA,oBAAoB,CAAc;EAO7C;AACF;AACA;AACA;AACA;AACA;EACE,OAAOC,OAAOA,CAACC,EAAU,EAAEC,MAAyB,EAAW;IAC7D,OAAO,IAAI;EACb;;EAEA;AACF;AACA;AACA;AACA;AACA;EACE,OAAOC,YAAYA,CACjBC,OAAiC,EACjCC,OAAiC,EACxB;IACT,MAAM,IAAIC,KAAK,CAAC,8BAA8B,CAAC;EACjD;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;EACE,OAAOC,UAAUA,CACfC,KAAa,EACbC,YAAoB,EACpBC,IAA2B,EACR;IACnB,OAAO;MAAEF,KAAK;MAAEC,YAAY;MAAEC;IAAK,CAAC;EACtC;;EAEA;AACF;AACA;AACA;AACA;EACER,MAAMA,CAACS,KAAQ,EAAET,MAAmC,EAAU;IAC5D,OAAO,EAAE;EACX;AACF;AAACU,eAAA,CArDYb,oBAAoB,iBACa,aAAa;AAAAa,eAAA,CAD9Cb,oBAAoB,yBAGqB,qBAAqB;AAAAa,eAAA,CAH9Db,oBAAoB,yBAKqB,qBAAqB;AAkD3E,eAAeA,oBAAoB"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@deephaven/jsapi-utils",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.51.1-alpha-theme-fix.1+add15f1b",
|
|
4
4
|
"description": "Deephaven JSAPI Utils",
|
|
5
5
|
"author": "Deephaven Data Labs LLC",
|
|
6
6
|
"license": "Apache-2.0",
|
|
@@ -21,15 +21,15 @@
|
|
|
21
21
|
"build:babel": "babel ./src --out-dir ./dist --extensions \".ts,.tsx,.js,.jsx\" --source-maps --root-mode upward"
|
|
22
22
|
},
|
|
23
23
|
"dependencies": {
|
|
24
|
-
"@deephaven/filters": "^0.
|
|
25
|
-
"@deephaven/jsapi-types": "^0.
|
|
26
|
-
"@deephaven/log": "^0.
|
|
27
|
-
"@deephaven/utils": "^0.
|
|
24
|
+
"@deephaven/filters": "^0.51.1-alpha-theme-fix.1+add15f1b",
|
|
25
|
+
"@deephaven/jsapi-types": "^0.51.1-alpha-theme-fix.1+add15f1b",
|
|
26
|
+
"@deephaven/log": "^0.51.1-alpha-theme-fix.1+add15f1b",
|
|
27
|
+
"@deephaven/utils": "^0.51.1-alpha-theme-fix.1+add15f1b",
|
|
28
28
|
"lodash.clamp": "^4.0.3",
|
|
29
29
|
"shortid": "^2.2.16"
|
|
30
30
|
},
|
|
31
31
|
"devDependencies": {
|
|
32
|
-
"@deephaven/jsapi-shim": "^0.
|
|
32
|
+
"@deephaven/jsapi-shim": "^0.51.1-alpha-theme-fix.1+add15f1b"
|
|
33
33
|
},
|
|
34
34
|
"files": [
|
|
35
35
|
"dist"
|
|
@@ -38,5 +38,5 @@
|
|
|
38
38
|
"publishConfig": {
|
|
39
39
|
"access": "public"
|
|
40
40
|
},
|
|
41
|
-
"gitHead": "
|
|
41
|
+
"gitHead": "add15f1b1ce7ad96bf40849a39c80434070b54c0"
|
|
42
42
|
}
|