@hpcc-js/timeline 3.0.0 → 3.1.0
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/index.js +1209 -32
- package/dist/index.js.map +1 -7
- package/dist/index.umd.cjs +2 -0
- package/dist/index.umd.cjs.map +1 -0
- package/package.json +17 -16
- package/src/ReactTimeline.ts +13 -2
- package/src/ReactTimelineSeries.ts +13 -2
- package/src/__package__.ts +1 -1
- package/types/__package__.d.ts +1 -1
package/dist/index.js.map
CHANGED
|
@@ -1,7 +1 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../src/__package__.ts", "../src/MiniGantt.ts", "../src/MiniGantt.css", "../src/ReactGantt.ts", "../src/ReactAxisGantt.ts", "../src/ReactAxisGanttSeries.ts", "../src/ReactTimeline.ts", "../src/ReactTimelineSeries.ts"],
|
|
4
|
-
"sourcesContent": ["export const PKG_NAME = \"@hpcc-js/timeline\";\nexport const PKG_VERSION = \"3.0.0\";\nexport const BUILD_VERSION = \"3.2.0\";\n", "import { ITooltip } from \"@hpcc-js/api\";\nimport { Axis } from \"@hpcc-js/chart\";\nimport { d3Event, EntityPin, EntityRect, local as d3Local, select as d3Select, SVGWidget, Utility } from \"@hpcc-js/common\";\nimport { extent as d3Extent } from \"d3-array\";\nimport { scaleBand as d3ScaleBand } from \"d3-scale\";\nimport { timeFormat as d3TimeFormat, timeParse as d3TimeParse } from \"d3-time-format\";\nimport { zoom as d3Zoom, zoomIdentity as d3ZoomIdentity } from \"d3-zoom\";\n\nimport \"../src/MiniGantt.css\";\n\nexport class MiniGantt extends SVGWidget {\n protected tlAxis: Axis;\n protected brAxis: Axis;\n protected verticalBands;\n protected _zoom;\n protected gUpperContent;\n protected gUpperAxis;\n protected gMiddleContent;\n protected gLowerAxis;\n protected gLowerContent;\n private localRect = d3Local<EntityRect>();\n private localEntityPin = d3Local<EntityPin>();\n private tooltipFormatter: (date: Date) => string;\n private _dateCache;\n\n protected rootExtent;\n protected _title_idx = 0;\n protected _startDate_idx = 1;\n protected _endDate_idx = 2;\n protected _icon_idx = -1;\n protected _color_idx = -1;\n protected _yoffset_idx = -1;\n\n constructor() {\n super();\n ITooltip.call(this);\n Utility.SimpleSelectionMixin.call(this);\n\n this._drawStartPos = \"origin\";\n this.tooltipHTML((d: any) => `<center>${d[this._title_idx]}</center><br>${this.tooltipFormatter(this.brAxis.parse(d[this._startDate_idx]))} -> ${this.tooltipFormatter(this.brAxis.parse(d[this._endDate_idx]))}`);\n\n this.tlAxis = new Axis()\n .type(\"time\")\n ;\n this.brAxis = new Axis()\n .type(\"time\")\n ;\n this.verticalBands = d3ScaleBand()\n .paddingOuter(0.2)\n .paddingInner(0.2)\n ;\n }\n\n isHorizontal(): boolean {\n return this.orientation() === \"horizontal\";\n }\n\n fullExtent() {\n const data = [...this.data().map(d => d[this._startDate_idx]), ...this.data().filter(d => !!d[this._endDate_idx]).map(d => d[this._endDate_idx])];\n return d3Extent(data);\n }\n\n extent() {\n const extent = this.rootExtent ? [this.rootExtent[1], this.rootExtent[2]] : this.fullExtent();\n if (extent[0] !== undefined && extent[1] !== undefined) {\n if (extent[0] === extent[1] || this.centerOnMostRecent()) {\n const parser = d3TimeParse(this.timePattern());\n const formatter = d3TimeFormat(this.timePattern());\n const date1 = parser(extent[0]);\n const date2 = parser(extent[1]);\n if (extent[0] === extent[1]) {\n extent[0] = formatter(new Date(date1.setFullYear(date1.getFullYear() - 1)));\n extent[1] = formatter(new Date(date1.setFullYear(date1.getFullYear() + 2)));\n } else {\n const time1 = date1.getTime();\n const timeDiff = date2.getTime() - time1;\n extent[0] = formatter(date1);\n extent[1] = formatter(new Date(time1 + (timeDiff * 2)));\n }\n }\n }\n return extent;\n }\n\n dataStartPos(d) {\n if (typeof this._dateCache[d[this._startDate_idx]] !== \"undefined\") {\n return this._dateCache[d[this._startDate_idx]];\n }\n const pos = this.brAxis.scalePos(d[this._startDate_idx]);\n this._dateCache[d[this._startDate_idx]] = pos;\n return pos;\n }\n\n dataEndPos(d) {\n if (typeof this._dateCache[d[this._endDate_idx]] !== \"undefined\") {\n return this._dateCache[d[this._endDate_idx]];\n }\n const pos = this.brAxis.scalePos(d[this._endDate_idx]);\n this._dateCache[d[this._endDate_idx]] = pos;\n return pos;\n }\n\n dataWidth(d) {\n return this.dataEndPos(d) - this.dataStartPos(d);\n }\n\n private transform;\n resetZoom() {\n // Triggers a \"zoomed\" event ---\n this._zoom.transform(this.element(), d3ZoomIdentity.translate(0, this.isHorizontal() ? 0 : this.height()));\n }\n\n zoomed() {\n this.transform = d3Event().transform;\n this.render();\n }\n\n private background;\n enter(domNode, element) {\n super.enter(domNode, element);\n this._zoom = d3Zoom()\n .scaleExtent([0, this.maxZoom()])\n .on(\"zoom\", () => {\n this.zoomed();\n })\n ;\n\n this.background = element.append(\"rect\")\n .attr(\"fill\", \"white\")\n .attr(\"opacity\", 0)\n .on(\"dblclick\", () => {\n d3Event().stopPropagation();\n delete this.rootExtent;\n this.resetZoom();\n })\n ;\n this.gUpperContent = element.append(\"g\").attr(\"class\", \"gUpperContent\");\n this.gUpperAxis = element.append(\"g\").attr(\"class\", \"gUpperAxis\");\n this.gMiddleContent = element.append(\"g\").attr(\"class\", \"gMiddleContent\");\n this.gLowerAxis = element.append(\"g\").attr(\"class\", \"gLowerAxis\");\n this.gLowerContent = element.append(\"g\").attr(\"class\", \"gLowerContent\");\n this.tlAxis\n .target(this.gUpperAxis.node())\n .tickFormat(this.tickFormat())\n .guideTarget(this.gUpperAxis.append(\"g\").node())\n .shrinkToFit(\"none\")\n .overlapMode(this.tickFormat_exists() ? \"stagger\" : \"none\")\n .extend(0.1)\n ;\n this.brAxis\n .target(this.gLowerAxis.node())\n .tickFormat(this.tickFormat())\n .guideTarget(this.gLowerAxis.append(\"g\").node())\n .shrinkToFit(\"none\")\n .overlapMode(this.tickFormat_exists() ? \"stagger\" : \"none\")\n .extend(0.1)\n ;\n\n element.call(this._zoom);\n this._selection.widgetElement(this.gMiddleContent);\n }\n\n private _prevIsHorizontal;\n update(domNode, element) {\n super.update(domNode, element);\n\n this._dateCache = {};\n\n this._title_idx = this.titleColumn() !== null ? this.columns().indexOf(this.titleColumn()) : this._title_idx;\n this._startDate_idx = this.startDateColumn() !== null ? this.columns().indexOf(this.startDateColumn()) : this._startDate_idx;\n this._endDate_idx = this.endDateColumn() !== null ? this.columns().indexOf(this.endDateColumn()) : this._endDate_idx;\n this._icon_idx = this.iconColumn() !== null ? this.columns().indexOf(this.iconColumn()) : this._icon_idx;\n this._color_idx = this.colorColumn() !== null ? this.columns().indexOf(this.colorColumn()) : this._color_idx;\n this._yoffset_idx = this.yOffsetColumn() !== null ? this.columns().indexOf(this.yOffsetColumn()) : this._yoffset_idx;\n\n if (this._prevIsHorizontal !== this.isHorizontal()) {\n this._prevIsHorizontal = this.isHorizontal();\n this.resetZoom();\n return;\n }\n\n this.tooltipFormatter = d3TimeFormat(this.tooltipTimeFormat());\n\n const width = this.width();\n const height = this.height();\n\n this.background\n .attr(\"x\", 0)\n .attr(\"y\", 0)\n .attr(\"width\", width)\n .attr(\"height\", height)\n ;\n\n const extent = this.extent();\n this.tlAxis\n .x(width / 2)\n .orientation(this.isHorizontal() ? \"top\" : \"left\")\n .reverse(!this.isHorizontal())\n .timePattern(this.timePattern()) // \"%Y-%m-%dT%H:%M:%S.%LZ\"\n .width(width - 1)\n .low(extent[0])\n .high(extent[1])\n .updateScale()\n ;\n\n this.brAxis\n .x(width / 2)\n .y(height / 2)\n .orientation(this.isHorizontal() ? \"bottom\" : \"right\")\n .reverse(!this.isHorizontal())\n .timePattern(this.timePattern()) // \"%Y-%m-%dT%H:%M:%S.%LZ\"\n .width(width - 1)\n .height(height)\n .low(extent[0])\n .high(extent[1])\n .updateScale()\n ;\n\n if (this.transform) {\n let low;\n let hi;\n if (this.isHorizontal()) {\n low = this.tlAxis.parseInvert(this.tlAxis.invert(this.transform.invertX(0)));\n hi = this.tlAxis.parseInvert(this.tlAxis.invert(this.transform.invertX(width - 1)));\n } else {\n low = this.tlAxis.parseInvert(this.tlAxis.invert(- this.transform.invertY(0)));\n hi = this.tlAxis.parseInvert(this.tlAxis.invert(- this.transform.invertY(height - 1)));\n }\n this.tlAxis\n .low(low)\n .high(hi)\n .updateScale()\n ;\n this.brAxis\n .low(low)\n .high(hi)\n .updateScale()\n ;\n }\n\n const data = this.data().sort(this.isHorizontal() ? (l, r) => {\n const retVal = this.brAxis.scalePos(l[1]) - this.brAxis.scalePos(r[1]);\n if (retVal === 0) {\n return (\"\" + l[0]).localeCompare(\"\" + r[0]);\n }\n return retVal;\n } : (l, r) => {\n return this.brAxis.scalePos(r[1]) - this.brAxis.scalePos(l[1]);\n });\n const events = data.filter(d => !d[this._endDate_idx]);\n const ranges = data.filter(d => !!d[this._endDate_idx]);\n\n this.tlAxis\n .render()\n ;\n this.brAxis\n .render()\n ;\n const brAxisBBox = this.brAxis.getBBox();\n\n let upperContentHeight = this.updateEntityPins(events);\n const lowerAxisHeight = brAxisBBox.height;\n let lowerHeight = height - upperContentHeight;\n const minYOffset = this._yoffset_idx !== -1 ? Math.min.apply(undefined, this.data().filter(row => !isNaN(row[this._yoffset_idx])).map(row => row[this._yoffset_idx])) : 0;\n if (events.length > 0 && ranges.length === 0) {\n // ONLY EVENTS\n this.tlAxis.visible(false);\n let y_offset = upperContentHeight / 4;\n if (y_offset > (height / 2) - lowerAxisHeight) {\n y_offset = (height / 2) - lowerAxisHeight;\n }\n const upperContentYOffset = (height / 2) + y_offset;\n const lowerAxisYOffset = ((height / 2) - lowerAxisHeight - y_offset) * -1;\n const halfMinYOffset = minYOffset !== 0 ? minYOffset / 2 : 0;\n this.gUpperContent.attr(\"transform\", `translate(0, ${upperContentYOffset - halfMinYOffset})`);\n this.gLowerAxis.attr(\"transform\", `translate(0, ${lowerAxisYOffset - halfMinYOffset})`);\n } else if (events.length === 0 && ranges.length > 0) {\n // ONLY RANGES\n this.tlAxis.visible(true);\n this.gUpperContent.attr(\"transform\", `translate(0, ${upperContentHeight})`);\n this.gUpperAxis.attr(\"transform\", `translate(0, ${upperContentHeight})`);\n } else {\n upperContentHeight -= minYOffset;\n lowerHeight += minYOffset;\n // BOTH\n this.tlAxis.visible(true);\n this.gUpperContent.attr(\"transform\", `translate(0, ${upperContentHeight})`);\n this.gUpperAxis.attr(\"transform\", `translate(0, ${upperContentHeight})`);\n this.gMiddleContent.attr(\"transform\", `translate(0, ${upperContentHeight})`);\n }\n this.tlAxis\n .render()\n ;\n const tlAxisBBox = this.tlAxis.getBBox();\n interface BucketInfo {\n endPos: number;\n }\n const bucketData: BucketInfo[] = [];\n const bucketIndex = {};\n for (const range of ranges) {\n for (let i = 0; i < bucketData.length; ++i) {\n const bucket = bucketData[i];\n if (bucket.endPos + this.overlapTolerence() <= this.dataStartPos(range)) {\n bucketIndex[range] = i;\n bucket.endPos = this.dataEndPos(range);\n break;\n }\n }\n\n if (bucketIndex[range] === undefined) {\n bucketIndex[range] = bucketData.length;\n bucketData.push({\n endPos: this.dataEndPos(range)\n });\n }\n }\n\n const vbLower = this.isHorizontal() ? 0 + tlAxisBBox.height : 0 + tlAxisBBox.width;\n const vbHigher = this.isHorizontal() ? lowerHeight - brAxisBBox.height : width - brAxisBBox.width;\n this.verticalBands\n .range([vbLower, vbHigher])\n .domain(bucketData.map((_d, i) => i))\n ;\n\n if (ranges.length > 0) {\n this.updateEventRanges(events, ranges, bucketIndex, lowerHeight, tlAxisBBox, brAxisBBox, width);\n }\n }\n\n updateEntityPins(events) {\n let event_height = 0;\n const context = this;\n const entityPins = this.gUpperContent.selectAll(\".entity_pin\").data(events, d => d[0] + \":\" + d[1]);\n const eventFontColor_idx = this.eventFontColorColumn() ? this.columns().indexOf(this.eventFontColorColumn()) : -1;\n const eventBorderColor_idx = this.eventBorderColorColumn() ? this.columns().indexOf(this.eventBorderColorColumn()) : -1;\n const eventBackgroundColor_idx = this.eventBackgroundColorColumn() ? this.columns().indexOf(this.eventBackgroundColorColumn()) : -1;\n const title_counts = {};\n for (const d of events) {\n const type = typeof d[context._title_idx] !== \"undefined\" ? d[context._title_idx] : d[0];\n title_counts[type] = title_counts[type] ? title_counts[type] + 1 : 1;\n }\n const title_types = Object.keys(title_counts);\n const title_group_offset = context.eventGroupOffset();\n const entityPinsEnter = entityPins.enter().append(\"g\")\n .attr(\"class\", \"entity_pin\");\n entityPinsEnter.append(\"line\")\n .attr(\"class\", \"entity_line\");\n\n entityPinsEnter\n .on(\"mouseover\", function (d) {\n d3Select(this).raise();\n })\n .each(function (d, i) {\n const entityPin = new EntityPin()\n .target(this)\n .icon(\"\uF024\")\n .iconOnlyShowOnHover(context.hideIconWhenCollapsed())\n .titleOnlyShowOnHover(context.hideTitleWhenCollapsed())\n .descriptionOnlyShowOnHover(context.hideDescriptionWhenCollapsed())\n .annotationOnlyShowOnHover(context.hideAnnotationsWhenCollapsed())\n .iconDiameter(18)\n .iconPaddingPercent(1)\n .titleFontSize(14)\n .descriptionColor(\"#333\")\n .descriptionFontSize(15)\n .iconColor(eventFontColor_idx === -1 ? \"#333\" : d[eventFontColor_idx])\n .titleColor(eventFontColor_idx === -1 ? \"#333\" : d[eventFontColor_idx])\n .descriptionColor(eventFontColor_idx === -1 ? \"#333\" : d[eventFontColor_idx])\n .backgroundShape(\"pin\")\n .backgroundColorFill(eventFontColor_idx === -1 ? \"#f8f8f8\" : d[eventBackgroundColor_idx])\n .backgroundColorStroke(eventFontColor_idx === -1 ? \"#ccc\" : d[eventBorderColor_idx])\n .cornerRadius(5)\n .arrowHeight(10)\n .arrowWidth(16)\n ;\n context.localEntityPin.set(this, entityPin);\n })\n .merge(entityPins)\n .each(function (d, i) {\n const entityPin = context.localEntityPin.get(this);\n const _title = typeof d[context._title_idx] !== \"undefined\" ? d[context._title_idx] : entityPin.title();\n const x_offset = context.dataStartPos(d) - 0;\n let y_offset = ((title_types.indexOf(_title) % context.eventGroupMod()) * title_group_offset) - 5;\n if (typeof d[context._yoffset_idx] !== \"undefined\") y_offset += d[context._yoffset_idx] ? d[context._yoffset_idx] : 0;\n if (d[context._title_idx] !== entityPin.title() && d[context._startDate_idx] !== entityPin.description()) {\n const parsed_start_time = context.brAxis.parse(d[context._startDate_idx]);\n const formatted_start_time = context.tooltipFormatter(parsed_start_time);\n entityPin\n .x(x_offset)\n .y(y_offset)\n .iconOnlyShowOnHover(context.hideIconWhenCollapsed())\n .titleOnlyShowOnHover(context.hideTitleWhenCollapsed())\n .descriptionOnlyShowOnHover(context.hideDescriptionWhenCollapsed())\n .annotationOnlyShowOnHover(context.hideAnnotationsWhenCollapsed())\n .icon(typeof d[context._icon_idx] !== \"undefined\" ? d[context._icon_idx] : entityPin.icon())\n .title(_title)\n .description(formatted_start_time)\n .animationFrameRender()\n ;\n } else {\n entityPin.move({ x: x_offset, y: y_offset });\n }\n const calc_height = entityPin.calcHeight();\n if (event_height < calc_height) event_height = calc_height;\n\n d3Select(this).selectAll(\".entity_line\")\n .attr(\"x1\", x_offset)\n .attr(\"x2\", x_offset)\n .attr(\"y1\", 0)\n .attr(\"y2\", y_offset)\n .style(\"stroke\", eventFontColor_idx === -1 ? \"#ccc\" : d[eventBorderColor_idx])\n .style(\"stroke-width\", 1)\n ;\n })\n ;\n entityPins.exit()\n .each(function (d, i) {\n const entityPin = context.localEntityPin.get(this);\n entityPin.target(null);\n\n })\n .remove();\n const event_offset = Math.abs(Math.min(events.length, context.eventGroupMod()) * context.eventGroupOffset());\n return event_height + event_offset;\n }\n\n updateEventRanges(events, ranges, bucketIndex, eventRangeHeight, tlAxisBBox, brAxisBBox, width) {\n const context = this;\n\n const lines = this.gMiddleContent.selectAll(\".line\").data(events, d => {\n return d[context._title_idx];\n });\n lines.enter().append(\"line\")\n .attr(\"class\", \"line\")\n .merge(lines)\n .attr(this.isHorizontal() ? \"x1\" : \"y1\", d => this.dataStartPos(d) - 0)\n .attr(this.isHorizontal() ? \"x2\" : \"y2\", d => this.dataStartPos(d) - 0)\n .attr(this.isHorizontal() ? \"y1\" : \"x1\", this.isHorizontal() ? tlAxisBBox.height : tlAxisBBox.width)\n .attr(this.isHorizontal() ? \"y2\" : \"x2\", this.isHorizontal() ? eventRangeHeight - brAxisBBox.height : width - brAxisBBox.width)\n ;\n lines.exit().remove();\n const buckets = this.gMiddleContent.selectAll(\".buckets\").data(ranges, d => d[context._title_idx]);\n buckets.enter().append(\"g\")\n .attr(\"class\", \"buckets\")\n .call(this._selection.enter.bind(this._selection))\n .each(function (d) {\n const entityRect = new EntityRect()\n .target(this)\n .iconDiameter(28)\n .iconPaddingPercent(0)\n .titleFontSize(28)\n .titleColor(context.rangeFontColor())\n .descriptionColor(context.rangeFontColor())\n .iconColor(context.rangeFontColor())\n .backgroundShape(\"rect\")\n .backgroundColorFill(d[context._color_idx])\n ;\n context.localRect.set(this, entityRect);\n context.enterEntityRect(entityRect, d);\n })\n .on(\"click\", function (d) {\n context.click(context.rowToObj(d), \"range\", context._selection.selected(this));\n }, false)\n .on(\"dblclick\", function (d) {\n context.rootExtent = d;\n context.resetZoom();\n context.dblclick(context.rowToObj(d), \"range\", context._selection.selected(this));\n }, true)\n .on(\"mouseout.tooltip\", this.tooltip.hide)\n .on(\"mousemove.tooltip\", this.tooltip.show)\n .merge(buckets)\n .attr(\"transform\", d => context.isHorizontal() ?\n `translate(${this.dataStartPos(d)}, ${this.verticalBands(bucketIndex[d])}) ` :\n `translate(${this.verticalBands(bucketIndex[d])}, ${this.dataStartPos(d)}) `)\n .each(function (d) {\n const textBox = context.localRect.get(this);\n const x = context.dataWidth(d) / 2;\n const y = context.verticalBands.bandwidth() / 2;\n const rectWidth = Math.max(context.dataWidth(d), 2);\n const rectHeight = Math.max(context.verticalBands.bandwidth(), 2);\n const fontHeightRatio = 0.618;\n const paddingRatio = ((1 - fontHeightRatio) / 2);\n const paddingSize = paddingRatio * rectHeight;\n const fontSize = rectHeight * fontHeightRatio;\n const iconSize = fontSize;\n textBox\n .pos(context.isHorizontal() ? { x, y } : { x: y, y: x })\n .fixedHeight(context.isHorizontal() ? rectHeight : rectWidth)\n .fixedWidth(context.isHorizontal() ? rectWidth : rectHeight)\n .icon(typeof d[context._icon_idx] !== \"undefined\" ? d[context._icon_idx] : \"\")\n .title(typeof d[context._title_idx] !== \"undefined\" ? d[context._title_idx] : \"\")\n .padding(paddingSize)\n .iconDiameter(iconSize)\n .titleFontSize(fontSize)\n ;\n if (iconSize * 1.5 > rectWidth) {\n textBox.icon(null);\n }\n context.updateEntityRect(textBox, d[context._icon_idx]);\n textBox\n .render()\n ;\n });\n buckets.exit().remove();\n }\n\n exit(domNode, element) {\n this.brAxis.target(null);\n this.tlAxis.target(null);\n super.exit(domNode, element);\n }\n\n // Events ---\n click(row, col, sel) {\n }\n\n dblclick(row, col, sel) {\n }\n\n enterEntityRect(textbox: EntityRect, d) {\n }\n\n updateEntityRect(textbox: EntityRect, d) {\n }\n}\nMiniGantt.prototype._class += \" timeline_MiniGantt\";\nMiniGantt.prototype.implements(ITooltip.prototype);\nMiniGantt.prototype.mixin(Utility.SimpleSelectionMixin);\n\nexport interface MiniGantt {\n // ITooltip ---\n tooltip;\n tooltipHTML(_): string;\n tooltipFormat(_): string;\n\n // SimpleSelectionMixin\n _selection;\n\n // Properties ---\n timePattern(): string;\n timePattern(_: string): this;\n tickFormat(): string;\n tickFormat(_: string): this;\n tickFormat_exists(): boolean;\n tooltipTimeFormat(): string;\n tooltipTimeFormat(_: string): this;\n overlapTolerence(): number;\n overlapTolerence(_: number): this;\n orientation(): string;\n orientation(_: string): this;\n rangeFontColor(): string;\n rangeFontColor(_: string): this;\n titleColumn(): string;\n titleColumn(_: string): this;\n startDateColumn(): string;\n startDateColumn(_: string): this;\n endDateColumn(): string;\n endDateColumn(_: string): this;\n iconColumn(): string;\n iconColumn(_: string): this;\n colorColumn(): string;\n colorColumn(_: string): this;\n yOffsetColumn(): string;\n yOffsetColumn(_: string): this;\n maxZoom(): number;\n maxZoom(_: number): this;\n eventGroupMod(): number;\n eventGroupMod(_: number): this;\n eventGroupOffset(): number;\n eventGroupOffset(_: number): this;\n eventFontColorColumn(): string;\n eventFontColorColumn(_: string): this;\n eventBorderColorColumn(): string;\n eventBorderColorColumn(_: string): this;\n eventBackgroundColorColumn(): string;\n eventBackgroundColorColumn(_: string): this;\n hideIconWhenCollapsed(): boolean;\n hideIconWhenCollapsed(_: boolean): this;\n hideTitleWhenCollapsed(): boolean;\n hideTitleWhenCollapsed(_: boolean): this;\n hideDescriptionWhenCollapsed(): boolean;\n hideDescriptionWhenCollapsed(_: boolean): this;\n hideAnnotationsWhenCollapsed(): boolean;\n hideAnnotationsWhenCollapsed(_: boolean): this;\n centerOnMostRecent(): boolean;\n centerOnMostRecent(_: boolean): this;\n\n}\n\nMiniGantt.prototype.publish(\"timePattern\", \"%Y-%m-%d\", \"string\", \"timePattern\");\nMiniGantt.prototype.publish(\"tickFormat\", null, \"string\", \"tickFormat\", undefined, { optional: true });\nMiniGantt.prototype.publish(\"tooltipTimeFormat\", \"%Y-%m-%d\", \"string\", \"tooltipTimeFormat\");\nMiniGantt.prototype.publish(\"overlapTolerence\", 2, \"number\", \"overlapTolerence\");\nMiniGantt.prototype.publish(\"orientation\", \"horizontal\", \"set\", \"orientation\", [\"horizontal\", \"vertical\"]);\nMiniGantt.prototype.publish(\"rangeFontColor\", \"#ecf0f1\", \"html-color\", \"rangeFontColor\");\nMiniGantt.prototype.publish(\"titleColumn\", null, \"string\", \"titleColumn\");\nMiniGantt.prototype.publish(\"startDateColumn\", null, \"string\", \"startDateColumn\");\nMiniGantt.prototype.publish(\"endDateColumn\", null, \"string\", \"endDateColumn\");\nMiniGantt.prototype.publish(\"iconColumn\", null, \"string\", \"iconColumn\");\nMiniGantt.prototype.publish(\"colorColumn\", null, \"string\", \"colorColumn\");\nMiniGantt.prototype.publish(\"yOffsetColumn\", null, \"string\", \"yOffsetColumn\");\nMiniGantt.prototype.publish(\"maxZoom\", 16, \"number\", \"maxZoom\");\nMiniGantt.prototype.publish(\"eventGroupOffset\", -50, \"number\", \"eventGroupOffset\");\nMiniGantt.prototype.publish(\"eventGroupMod\", 5, \"number\", \"eventGroupMod\");\nMiniGantt.prototype.publish(\"eventFontColorColumn\", null, \"string\", \"eventFontColorColumn\");\nMiniGantt.prototype.publish(\"eventBorderColorColumn\", null, \"string\", \"eventBorderColorColumn\");\nMiniGantt.prototype.publish(\"eventBackgroundColorColumn\", null, \"string\", \"eventBackgroundColorColumn\");\nMiniGantt.prototype.publish(\"hideIconWhenCollapsed\", false, \"boolean\", \"hideIconWhenCollapsed\");\nMiniGantt.prototype.publish(\"hideTitleWhenCollapsed\", false, \"boolean\", \"hideTitleWhenCollapsed\");\nMiniGantt.prototype.publish(\"hideDescriptionWhenCollapsed\", false, \"boolean\", \"hideDescriptionWhenCollapsed\");\nMiniGantt.prototype.publish(\"hideAnnotationsWhenCollapsed\", true, \"boolean\", \"hideAnnotationsWhenCollapsed\");\nMiniGantt.prototype.publish(\"centerOnMostRecent\", false, \"boolean\", \"If true, the timeline will be centered on the most recent data point\");\n", "(function(){\n if (!document.getElementById('815a87be')) {\n var e = document.createElement('style');\n e.id = '815a87be';\n e.textContent = `.timeline_MiniGantt .line {\n fill: none;\n stroke: lightgrey;\n opacity: 0.7;\n}\n\n.timeline_MiniGantt .common_TextBox .rect {\n fill: lightskyblue;\n stroke: blue;\n opacity: 0.5;\n}\n\n.timeline_MiniGantt .buckets .entity_shape rect {\n stroke: #333;\n}\n\n.timeline_MiniGantt .buckets.selected .common_EntityRect .common_Shape > rect {\n stroke: red;\n}\n\n.timeline_MiniGantt .common_TextBox .rect text {\n fill: black;\n stroke: none;\n}\n.timeline_MiniGantt .over {\n stroke: transparent;\n opacity: 0.8;\n}\n.timeline_MiniGantt rect {\n shape-rendering: crispEdges;\n}`;\n document.head.appendChild(e);\n }\n })();", "import { d3Event, select as d3Select, SVGZoomWidget, Utility } from \"@hpcc-js/common\";\nimport { HTMLTooltip } from \"@hpcc-js/html\";\nimport { scaleLinear as d3ScaleLinear } from \"d3-scale\";\nimport { React, render, LabelledRect } from \"@hpcc-js/react\";\n\nexport type IGanttData = [string, number, number, any?];\n\nexport interface IRangeOptions {\n rangePadding: number;\n fontFamily: string;\n fontSize: number;\n strokeWidth?: number;\n fill: string;\n stroke: string;\n textFill: string;\n cornerRadius: number;\n}\n\nexport class ReactGantt extends SVGZoomWidget {\n\n protected _selection = new Utility.Selection(this);\n\n protected _buckets;\n protected _interpolateX;\n protected _interpolateY;\n\n protected _bucketsBySeries;\n protected _dataBySeries;\n protected _origIdxMap;\n private _seriesBackgrounds;\n\n protected _maxFontSize;\n\n public _tooltip;\n\n public _minStart: number;\n public _maxEnd: number;\n\n protected _title_idx = 0;\n protected _startDate_idx = 1;\n protected _endDate_idx = 2;\n protected _icon_idx = -1;\n protected _color_idx = -1;\n protected _series_idx = -1;\n protected _bucket_idx = -1;\n protected _yoffset_idx = -1;\n\n protected _maxX: number;\n protected _maxY: number;\n\n private _rangeOptions: IRangeOptions = {\n rangePadding: 2,\n fontFamily: \"Verdana\",\n fontSize: 12,\n fill: \"white\",\n stroke: \"black\",\n textFill: \"black\",\n cornerRadius: 3,\n strokeWidth: 0\n };\n\n constructor(drawStartPosition: \"origin\" | \"center\" = \"origin\") {\n super();\n this._drawStartPos = drawStartPosition;\n\n this.showToolbar_default(false);\n\n this._tooltip = new HTMLTooltip();\n this._tooltip\n .tooltipHTML(d => {\n return `<div style=\"text-align:center;\">${d[0]}<br/><br/>${d[1]} -> ${d[2]}</div>`;\n });\n this._tooltip\n .followCursor(true)\n ;\n }\n\n selection(_: any[]): this;\n selection(): any[];\n selection(_?: any[]): any[] | this {\n if (!arguments.length) return this._selection.get();\n this._selection.set(_);\n return this;\n }\n\n private _rangeRenderer: React.FunctionComponent = LabelledRect;\n rangeRenderer(): React.FunctionComponent;\n rangeRenderer(_: React.FunctionComponent): this;\n rangeRenderer(_?: React.FunctionComponent): this | React.FunctionComponent {\n if (!arguments.length) return this._rangeRenderer;\n this._rangeRenderer = _;\n return this._rangeRenderer;\n }\n\n enter(domNode, element) {\n super.enter(domNode, element);\n\n const context = this;\n element\n .on(\"click\", function (this: SVGElement, d) {\n context._selection.clear();\n });\n\n this._tooltip.target(domNode);\n }\n update(domNode, element) {\n super.update(domNode, element);\n\n this.zoomExtent([0.05, this.maxZoom()]);\n\n this._title_idx = this.titleColumn() !== null ? this.columns().indexOf(this.titleColumn()) : this._title_idx;\n this._startDate_idx = this.startDateColumn() !== null ? this.columns().indexOf(this.startDateColumn()) : this._startDate_idx;\n this._endDate_idx = this.endDateColumn() !== null ? this.columns().indexOf(this.endDateColumn()) : this._endDate_idx;\n this._icon_idx = this.iconColumn() !== null ? this.columns().indexOf(this.iconColumn()) : this._icon_idx;\n this._color_idx = this.colorColumn() !== null ? this.columns().indexOf(this.colorColumn()) : this._color_idx;\n this._series_idx = this.seriesColumn() !== null ? this.columns().indexOf(this.seriesColumn()) : this._series_idx;\n this._bucket_idx = this.bucketColumn() !== null ? this.columns().indexOf(this.bucketColumn()) : -1;\n\n const context = this;\n const w = this.width();\n\n const x0 = 0;\n const x1 = w;\n\n this._interpolateX = d3ScaleLinear()\n .domain([this._minStart, this._maxEnd])\n .range([x0, x1])\n ;\n\n this.data().sort((a, b) => a[1] - b[1]);\n\n if (this._series_idx > -1) {\n this._origIdxMap = {};\n this._dataBySeries = {};\n this._bucketsBySeries = {};\n this.data().forEach((dataRow, origIdx) => {\n const seriesKey = dataRow[this._series_idx];\n if (!this._dataBySeries[seriesKey]) {\n this._origIdxMap[seriesKey] = {};\n this._dataBySeries[seriesKey] = [];\n }\n this._dataBySeries[seriesKey].push({\n dataRow,\n origIdx\n });\n });\n const gutter = this.gutter();\n let bucketOffset = 0;\n const seriesKeys = Object.keys(this._dataBySeries);\n seriesKeys.forEach(seriesKey => {\n this._dataBySeries[seriesKey].sort((a, b) => a.dataRow[1] - b.dataRow[1]);\n this._bucketsBySeries[seriesKey] = this.calcBuckets(this._dataBySeries[seriesKey].map(n => n.dataRow), 1, 2);\n this._bucketsBySeries[seriesKey].bucketHeight = this.bucketHeight();\n this._bucketsBySeries[seriesKey].bucketOffset = bucketOffset;\n bucketOffset += (this._bucketsBySeries[seriesKey].bucketHeight + this.strokeWidth() + this.gutter()) * (this._bucketsBySeries[seriesKey].maxBucket + 1);\n this._dataBySeries[seriesKey].forEach((n, i) => {\n this._origIdxMap[seriesKey][n.origIdx] = i;\n });\n });\n this._seriesBackgrounds = this._renderElement.selectAll(\".series-background\")\n .data(seriesKeys.map(key => {\n return this._bucketsBySeries[key];\n }))\n ;\n this._seriesBackgrounds\n .join(\n enter => enter.append(\"rect\")\n .attr(\"class\", \"series-background\"),\n update => update,\n exit => exit\n .each(function (d) {\n delete d.element;\n })\n .remove()\n )\n .attr(\"opacity\", d => d.props && d.props.hidden ? 0 : 1)\n .each(function (this: SVGGElement, d, i) {\n d3Select(this)\n .attr(\"x\", 0)\n .attr(\"y\", d.bucketOffset - (gutter / 2))\n .attr(\"width\", w)\n .attr(\"height\", ((d.bucketHeight + gutter) * (d.maxBucket + 1)) + gutter)\n .attr(\"fill\", i % 2 ? context.oddSeriesBackground() : context.evenSeriesBackground())\n ;\n });\n } else {\n if (this._bucket_idx !== -1) {\n this._buckets = this.calcBuckets(this.data(), this._startDate_idx, this._endDate_idx, this._bucket_idx);\n } else {\n this._buckets = this.calcBuckets(this.data(), this._startDate_idx, this._endDate_idx);\n }\n }\n const interpedStart = this._interpolateX(this._minStart);\n\n this.zoomTo(\n [interpedStart, 0],\n 1\n );\n\n const bucketHeight = this.bucketHeight();\n\n this.setRangeOptions();\n\n this._maxFontScale = (bucketHeight - (this.rangePadding() * 2));\n this.measureDataText();\n\n const itemSelection = this._renderElement.selectAll(\".item\")\n .data(this.data())\n ;\n const borderOffset1 = this.strokeWidth();\n const borderOffset2 = borderOffset1 * 2;\n itemSelection\n .join(\n enter => enter.append(\"g\")\n .attr(\"class\", \"item\")\n .on(\"click.selectionBag\", function (d, i) {\n const _id = d.id === undefined ? i : d.id;\n if (context._selection.isSelected({ _id, element: d.element })) {\n context._selection.clear();\n } else {\n context._selection.click(\n {\n _id,\n element: () => d.element\n },\n d3Event\n );\n }\n context.selectionChanged();\n d3Event().stopPropagation();\n })\n .on(\"click\", function (this: SVGElement, d) {\n const selected = d.element.classed(\"selected\");\n if (d[context.columns().length]) {\n d.__lparam = d[context.columns().length];\n }\n context.click(d, \"\", selected);\n })\n .on(\"dblclick\", function (this: SVGElement, d) {\n const selected = d.element.classed(\"selected\");\n if (d[context.columns().length]) {\n d.__lparam = d[context.columns().length];\n }\n context.click(d, \"\", selected);\n })\n .on(\"mousein\", function (d) {\n context.highlightItem(d3Select(this), d);\n const selected = d.element.classed(\"selected\");\n context.mousein(d, \"\", selected);\n })\n .on(\"mouseover\", function (d) {\n const d3evt = d3Event();\n context._tooltip._triggerElement = d.element;\n context._tooltip._cursorLoc = [\n d3evt.clientX,\n d3evt.clientY\n ];\n context._tooltip\n .data(d)\n .visible(true)\n .fitContent(true)\n .render()\n ;\n context.highlightItem(d3Select(this), d);\n const selected = d.element.classed(\"selected\");\n context.mouseover(d, \"\", selected);\n })\n .on(\"mouseout\", function (d) {\n context._tooltip\n .visible(false)\n .render()\n ;\n context.highlightItem(null, null);\n const selected = d.element.classed(\"selected\");\n context.mouseout(d, \"\", selected);\n })\n .each(function (d, i) {\n d.that = this;\n d.element = d3Select(this);\n d.x = context._interpolateX(d[1]);\n const endX = context._interpolateX(d[2]);\n if (context._series_idx > -1) {\n const seriesKey = d[context._series_idx];\n const bucket = context._bucketsBySeries[seriesKey].bucketMap[context._origIdxMap[seriesKey][i]];\n d.y = context._bucketsBySeries[seriesKey].interpolateY(bucket) + context._bucketsBySeries[seriesKey].bucketOffset;\n } else {\n const _i = context._bucket_idx === -1 ? i : d[context._bucket_idx];\n d.y = context._buckets.interpolateY(context._buckets.bucketMap[_i]);\n }\n d.props = {\n ...d[3],\n text: d[0]\n };\n d.props.width = endX - d.x;\n d.props.height = bucketHeight;\n d.x += borderOffset1;\n d.y += borderOffset1;\n d.props.width -= borderOffset2;\n d.props.height -= borderOffset2;\n d.element.attr(\"transform\", `translate(${d.x + (d.props.width / 2)} ${d.y + (d.props.height / 2)})`);\n }),\n update => update,\n exit => exit\n .each(function (d) {\n delete d.element;\n })\n .remove()\n )\n .attr(\"opacity\", d => d.props && d.props.hidden ? 0 : 1)\n .each(function (this: SVGGElement, d, i) {\n d.that = this;\n if (context._series_idx > -1) {\n const seriesKey = d[context._series_idx];\n d.x = context.renderRangeElement(d, i, false, context._rangeOptions, seriesKey);\n } else {\n d.x = context.renderRangeElement(d, i, false, context._rangeOptions);\n }\n })\n .on(\"dblclick.zoom\", d => {\n const x1 = this._interpolateX(d[1]);\n const x2 = this._interpolateX(d[2]);\n const xRange = x2 - x1;\n const xScale = w / xRange;\n this.zoomTo(\n [\n -x1 * xScale,\n 0\n ],\n xScale\n );\n })\n ;\n element.on(\"dblclick.zoom\", null);\n }\n exit(domNode, element) {\n this._tooltip.target(null);\n super.exit(domNode, element);\n }\n renderRangeElement(d, i, transformEach = false, options: any = {}, seriesKey?: string) {\n const borderOffset1 = options.strokeWidth;\n const borderOffset2 = borderOffset1 * 2;\n const padding = options.rangePadding;\n let endX;\n const x = isNaN(this._transform.x) ? 0 : this._transform.x;\n const k = isNaN(this._transform.k) ? 1 : this._transform.k;\n let b;\n const bucketHeight = this.bucketHeight();\n d.that.setAttribute(\"data-series\", seriesKey);\n\n if (this._color_idx > -1) {\n d.that.setAttribute(\"data-color\", d[this._color_idx]);\n }\n\n if (seriesKey !== undefined) {\n b = this._bucketsBySeries[seriesKey].bucketMap[this._origIdxMap[seriesKey][i]];\n d.that.setAttribute(\"data-b\", b);\n d.that.setAttribute(\"data-bucketOffset\", this._bucketsBySeries[seriesKey].bucketOffset);\n d.y = this._bucketsBySeries[seriesKey].interpolateY(b) + this._bucketsBySeries[seriesKey].bucketOffset;\n d.that.setAttribute(\"data-dy\", d.y);\n } else {\n b = this._buckets.bucketMap[i];\n d.y = this._buckets.interpolateY(b);\n }\n if (this._color_idx > -1) {\n options.fill = d[this._color_idx];\n }\n if (!transformEach) {\n d.x = this._interpolateX(d[1]);\n endX = this._interpolateX(d[2]);\n d.props = {\n ...d[3],\n text: d[0]\n };\n d.props.width = (endX - d.x) / k;\n } else {\n d.x = this._interpolateX(d[1]) * k;\n endX = this._interpolateX(d[2]) * k;\n d.props = {\n ...d[3],\n text: d[0]\n };\n d.props.width = (endX - d.x) / k;\n d.x += x;\n d.props.width *= k;\n }\n d.props.height = bucketHeight;\n if (seriesKey === undefined && this._buckets.bucketScale < 1) {\n d.props.height = this._buckets.bucketScale * bucketHeight;\n }\n if (d.element === undefined && d.that) {\n d.element = d3Select(d.that);\n }\n d.element.attr(\"transform\", `translate(${d.x + (d.props.width / 2)} ${d.y + (d.props.height / 2)})`);\n\n d.x += borderOffset1;\n d.y += borderOffset1;\n d.props.width -= borderOffset2;\n d.props.height -= borderOffset2;\n d.props.width = d.props.width < 1 ? 1 : d.props.width;\n d.props.height = d.props.height < 1 ? 1 : d.props.height;\n\n let text = this.truncateText(d.props.text, d.props.width - padding, this._maxFontScale);\n\n if (text !== d.props.text) {\n text = this.truncateText(d.props.text, d.props.width - padding);\n } else {\n d.props.fontSize = this._maxFontScale * options.fontSize;\n }\n if (seriesKey === undefined && this._buckets.bucketScale < 1) {\n d.props.fontSize = Math.min(this._maxFontScale, this._buckets.bucketScale) * options.fontSize;\n }\n if (!this._maxY || this._maxY < d.y + d.props.height) {\n this._maxY = d.y + d.props.height;\n }\n if (!this._maxX || this._maxX < d.x + d.props.width) {\n this._maxX = d.x + d.props.width;\n }\n render(\n this._rangeRenderer,\n {\n ...options,\n ...d.props,\n text,\n },\n d.that\n );\n }\n\n setRangeOptions() {\n this._rangeOptions = {\n rangePadding: this.rangePadding(),\n fontFamily: this.fontFamily(),\n fontSize: this.fontSize(),\n strokeWidth: this.strokeWidth(),\n fill: this.fill(),\n stroke: this.stroke(),\n textFill: this.rangeFontColor(),\n cornerRadius: this.cornerRadius(),\n };\n }\n\n public _transform = { k: 1, x: 0, y: 0 };\n zoomed(transform) {\n this._transform = transform;\n switch (this.renderMode()) {\n case \"scale-all\":\n this._zoomScale = transform.k;\n this._zoomTranslate = [transform.x, 0];\n this._zoomG.attr(\"transform\", `translate(${transform.x} ${0})scale(${transform.k} 1)`);\n break;\n default:\n const options = this._rangeOptions;\n this.data().forEach((d, i) => {\n if (this._color_idx > -1) {\n options.fill = d[this._color_idx];\n }\n if (this._series_idx > -1) {\n const seriesKey = d[this._series_idx];\n this.renderRangeElement(d, i, true, options, seriesKey);\n } else {\n this.renderRangeElement(d, i, true, options);\n }\n });\n }\n\n this.zoomedHook(transform);\n }\n\n zoomedHook(transform) {\n\n }\n\n private calcBuckets(data, startKey: string | number, endKey: string | number, bucketKey?: string | number) {\n const bucketMap = {};\n const bucketKeyMap = {};\n const tol = this.overlapTolerence();\n const buckets = [{ end: -Infinity }];\n let maxBucket = 0;\n if (bucketKey !== undefined) {\n data.forEach((d, i) => {\n bucketMap[i] = d[bucketKey];\n bucketKeyMap[d[bucketKey]] = true;\n });\n maxBucket = Object.keys(bucketKeyMap).length;\n } else {\n data.forEach((d, i) => {\n for (let i2 = 0; i2 < buckets.length; ++i2) {\n if (i === 0 || buckets[i2][endKey] + tol <= d[startKey]) {\n bucketMap[i] = i2;\n if (maxBucket < i2) maxBucket = i2;\n buckets[i2][endKey] = d[endKey];\n break;\n }\n }\n if (bucketMap[i] === undefined) {\n bucketMap[i] = buckets.length;\n const b = {};\n b[endKey] = d[endKey];\n buckets.push(b as any);\n }\n\n if (maxBucket < bucketMap[i]) maxBucket = bucketMap[i];\n });\n }\n const height = (maxBucket + 1) * (this.bucketHeight() + this.gutter());\n return {\n bucketMap,\n maxBucket,\n bucketScale: this.height() / height,\n interpolateY: d3ScaleLinear()\n .domain([0, maxBucket + 1])\n .range([0, Math.min(this.height(), height)])\n };\n }\n\n data(): IGanttData[];\n data(_: IGanttData[]): this;\n data(_?: IGanttData[]): this | IGanttData[] {\n const retVal = super.data.apply(this, arguments);\n if (arguments.length > 0) {\n this._minStart = Math.min(...this.data().map(n => n[1])) ?? 0;\n this._maxEnd = Math.max(...this.data().map(n => n[2])) ?? 1;\n this.measureDataText(true);\n }\n return retVal;\n }\n\n protected _textWidths;\n protected _maxFontScale;\n protected _characterWidths;\n protected _prevFontFamily;\n protected _prevFontSize;\n measureDataText(forceMeasure = false) {\n const textWidths = {};\n const characterWidths = {};\n const fontFamily = this.fontFamily();\n const fontSize = this.fontSize();\n const bucketHeight = this.bucketHeight();\n\n if (bucketHeight) {\n this._maxFontScale = (bucketHeight - (this.rangePadding() * 2)) / fontSize;\n }\n\n if (forceMeasure || this._prevFontFamily !== fontFamily || this._prevFontSize !== fontSize) {\n characterWidths[\".\"] = Utility.textSize(\".\", fontFamily, fontSize).width;\n this.data().forEach(d => {\n if (!textWidths[d[0]]) {\n textWidths[d[0]] = Utility.textSize(d[0], fontFamily, fontSize).width;\n }\n d[0].split(\"\").forEach(char => {\n if (!characterWidths[char]) {\n characterWidths[char] = Utility.textSize(char, fontFamily, fontSize).width;\n }\n });\n });\n this._textWidths = textWidths;\n this._characterWidths = characterWidths;\n }\n this._prevFontFamily = fontFamily;\n this._prevFontSize = fontSize;\n }\n\n truncateText(text, width, scale = 1) {\n const textFits = this._textWidths[text] * scale < width;\n if (textFits) {\n return text;\n }\n let ret = \"\";\n let sum = 0;\n const _width = width - (this._characterWidths[\".\"] * 3);\n for (const char of text) {\n sum += this._characterWidths[char];\n if (sum < _width) {\n ret += char;\n } else {\n break;\n }\n }\n return _width < 0 ? \"\" : ret + \"...\";\n }\n\n resize(_size?: { width: number, height: number }) {\n let retVal;\n if (this.fitWidthToContent() || this.fitHeightToContent()) {\n retVal = super.resize.call(this, {\n width: _size.width,\n height: this._maxY\n });\n } else {\n retVal = super.resize.apply(this, arguments);\n }\n return retVal;\n }\n\n selectionChanged() {\n\n }\n\n highlightItem(_element, d) {\n\n }\n\n click(row, _col, sel) {\n\n }\n\n dblclick(row, _col, sel) {\n\n }\n\n mousein(row, _col, sel) {\n }\n\n mouseover(row, _col, sel) {\n }\n\n mouseout(row, _col, sel) {\n }\n}\nReactGantt.prototype._class += \" timeline_ReactGantt\";\n\nexport interface ReactGantt {\n titleColumn(): string;\n titleColumn(_: string): this;\n startDateColumn(): string;\n startDateColumn(_: string): this;\n endDateColumn(): string;\n endDateColumn(_: string): this;\n iconColumn(): string;\n iconColumn(_: string): this;\n colorColumn(): string;\n colorColumn(_: string): this;\n seriesColumn(): string;\n seriesColumn(_: string): this;\n bucketColumn(): string;\n bucketColumn(_: string): this;\n overlapTolerence(): number;\n overlapTolerence(_: number): this;\n smallestRangeWidth(): number;\n smallestRangeWidth(_: number): this;\n bucketHeight(): number;\n bucketHeight(_: number): this;\n gutter(): number;\n gutter(_: number): this;\n showToolbar_default(_: boolean): this;\n fontSize(): number;\n fontSize(_: number): this;\n fontFamily(): string;\n fontFamily(_: string): this;\n strokeWidth(): number;\n strokeWidth(_: number): this;\n stroke(): string;\n stroke(_: string): this;\n cornerRadius(): number;\n cornerRadius(_: number): this;\n fill(): string;\n fill(_: string): this;\n rangeFontColor(): string;\n rangeFontColor(_: string): this;\n rangePadding(): number;\n rangePadding(_: number): this;\n renderMode(): \"default\" | \"scale-all\";\n renderMode(_: \"default\" | \"scale-all\"): this;\n maxZoom(): number;\n maxZoom(_: number): this;\n fitWidthToContent(): boolean;\n fitWidthToContent(_: boolean): this;\n fitHeightToContent(): boolean;\n fitHeightToContent(_: boolean): this;\n evenSeriesBackground(): string;\n evenSeriesBackground(_: string): this;\n oddSeriesBackground(): string;\n oddSeriesBackground(_: string): this;\n}\n\nReactGantt.prototype.publish(\"fitWidthToContent\", false, \"boolean\", \"If true, resize will simply reapply the bounding box width\");\nReactGantt.prototype.publish(\"fitHeightToContent\", false, \"boolean\", \"If true, resize will simply reapply the bounding box height\");\nReactGantt.prototype.publish(\"titleColumn\", null, \"string\", \"Column name to for the title\");\nReactGantt.prototype.publish(\"startDateColumn\", null, \"string\", \"Column name to for the start date\");\nReactGantt.prototype.publish(\"endDateColumn\", null, \"string\", \"Column name to for the end date\");\nReactGantt.prototype.publish(\"iconColumn\", null, \"string\", \"Column name to for the icon\");\nReactGantt.prototype.publish(\"colorColumn\", null, \"string\", \"Column name to for the color\");\nReactGantt.prototype.publish(\"seriesColumn\", null, \"string\", \"Column name to for the series identifier\");\nReactGantt.prototype.publish(\"bucketColumn\", null, \"string\", \"Column name to for the bucket identifier\");\nReactGantt.prototype.publish(\"renderMode\", \"default\", \"set\", \"Render modes vary in features and performance\", [\"default\", \"scale-all\"]);\nReactGantt.prototype.publish(\"rangePadding\", 3, \"number\", \"Padding within each range rectangle (pixels)\");\nReactGantt.prototype.publish(\"fill\", \"#1f77b4\", \"string\", \"Background color of range rectangle\");\nReactGantt.prototype.publish(\"stroke\", null, \"string\", \"Color of range rectangle border\");\nReactGantt.prototype.publish(\"strokeWidth\", null, \"number\", \"Width of range rectangle border (pixels)\");\nReactGantt.prototype.publish(\"cornerRadius\", 3, \"number\", \"Space between range buckets (pixels)\");\nReactGantt.prototype.publish(\"fontFamily\", null, \"string\", \"Font family within range rectangle\", null, { optional: true });\nReactGantt.prototype.publish(\"fontSize\", 10, \"number\", \"Size of font within range rectangle (pixels)\");\nReactGantt.prototype.publish(\"rangeFontColor\", \"#ecf0f1\", \"html-color\", \"rangeFontColor\");\nReactGantt.prototype.publish(\"overlapTolerence\", 2, \"number\", \"overlapTolerence\");\nReactGantt.prototype.publish(\"smallestRangeWidth\", 10, \"number\", \"Width of the shortest range (pixels)\");\nReactGantt.prototype.publish(\"bucketHeight\", 100, \"number\", \"Max height of range element (pixels)\");\nReactGantt.prototype.publish(\"gutter\", 2, \"number\", \"Space between range buckets (pixels)\");\nReactGantt.prototype.publish(\"maxZoom\", 16, \"number\", \"Maximum zoom\");\nReactGantt.prototype.publish(\"evenSeriesBackground\", \"#FFFFFF\", \"html-color\", \"Background color of even series rows\");\nReactGantt.prototype.publish(\"oddSeriesBackground\", \"#DDDDDD\", \"html-color\", \"Background color of odd series rows\");\n", "import { Axis } from \"@hpcc-js/chart\";\nimport { SVGWidget } from \"@hpcc-js/common\";\nimport { ReactGantt } from \"./ReactGantt.ts\";\n\nexport type IAxisGanttData = [string, number | string, number | string, any?] | any[];\n\nexport class ReactAxisGantt extends SVGWidget {\n\n protected _topAxis: Axis = new Axis(\"center\")\n .orientation(\"top\")\n .type(\"linear\")\n .shrinkToFit(\"none\")\n .overlapMode(\"hide\")\n .extend(0)\n .tickFormat(\"d\")\n ;\n protected _gantt: ReactGantt = new ReactGantt(\"center\")\n .stroke(\"#000000\")\n ;\n protected _bottomAxis: Axis = new Axis(\"center\")\n .orientation(\"bottom\")\n .type(\"linear\")\n .shrinkToFit(\"none\")\n .overlapMode(\"hide\")\n .extend(0)\n .tickFormat(\"d\")\n ;\n\n protected _topAxisElement;\n protected _contentElement;\n protected _bottomAxisElement;\n protected _topRect;\n protected _contentRect;\n protected _bottomRect;\n\n protected rangeRenderer;\n\n constructor() {\n super();\n this._drawStartPos = \"origin\";\n this.rangeRenderer = function () {\n const ret = this._gantt.rangeRenderer.apply(this._gantt, arguments);\n if (!arguments.length) return ret;\n return this;\n };\n }\n\n selection(_: any[]): this;\n selection(): any[];\n selection(_?: any[]): any[] | this {\n if (!arguments.length) return this._gantt.selection();\n this._gantt.selection(_);\n return this;\n }\n\n resizeWrappers() {\n\n const w = this.width();\n const h = this.height();\n\n const axisHeight = this.axisHeight(); //TODO: Dynamic scaling to allow for small resolutions?\n\n const contentHeight = (h - (axisHeight * 2));\n const borderOffset1 = this.strokeWidth();\n this._topRect\n .attr(\"height\", axisHeight)\n .attr(\"width\", w)\n .attr(\"fill\", \"transparent\")\n ;\n this._topAxisElement.attr(\"transform\", \"translate(0 0)\");\n this._topAxis.resize({ height: axisHeight, width: w });\n this._contentRect\n .attr(\"height\", contentHeight)\n .attr(\"width\", w)\n .attr(\"fill\", \"transparent\")\n ;\n this._contentElement.attr(\"transform\", `translate(0 ${axisHeight + borderOffset1})`);\n this._gantt.resize({ height: contentHeight, width: w });\n this._bottomRect\n .attr(\"height\", axisHeight)\n .attr(\"width\", w)\n .attr(\"fill\", \"transparent\")\n ;\n this._bottomAxisElement.attr(\"transform\", `translate(0 ${axisHeight + contentHeight + borderOffset1})`);\n this._bottomAxis.resize({ height: axisHeight, width: w });\n }\n\n enter(domNode, element) {\n super.enter(domNode, element);\n\n this._gantt.click = (row, col, sel) => {\n this.click(row, col, sel);\n };\n\n this._gantt.dblclick = (row, col, sel) => {\n this.dblclick(row, col, sel);\n };\n\n this._topAxisElement = element.append(\"g\")\n .attr(\"class\", \"top-axis-wrapper\")\n ;\n this._topRect = this._topAxisElement.append(\"rect\")\n .attr(\"class\", \"top-axis-rect\")\n ;\n this._contentElement = element.append(\"g\")\n .attr(\"class\", \"content-wrapper\")\n ;\n this._contentRect = this._contentElement.append(\"rect\")\n .attr(\"class\", \"content-rect\")\n ;\n this._bottomAxisElement = element.append(\"g\")\n .attr(\"class\", \"bottom-axis-wrapper\")\n ;\n this._bottomRect = this._bottomAxisElement.append(\"rect\")\n .attr(\"class\", \"top-axis-rect\")\n ;\n this._topAxis.target(this._topAxisElement.node());\n this._gantt.target(this._contentElement.node()).bucketHeight(30);\n this._bottomAxis.target(this._bottomAxisElement.node());\n\n this.resizeWrappers();\n\n this._gantt.zoomedHook = (transform) => {\n this.onzoom(transform);\n };\n }\n\n onzoom(transform) {\n\n const w = this.width();\n const low = this._gantt._minStart;\n const high = this._gantt._maxEnd;\n const range = high - low;\n const wpp = range / w;\n const nextLow = Math.floor(low - (wpp * (transform.x / transform.k)));\n const nextHigh = Math.ceil((range / transform.k) + nextLow);\n\n this._topAxis\n .fontFamily(this.axisFontFamily())\n .fontSize(this.axisFontSize())\n .tickLength(this.axisTickLength())\n .low(nextLow)\n .high(nextHigh)\n .render()\n ;\n this._bottomAxis\n .fontFamily(this.axisFontFamily())\n .fontSize(this.axisFontSize())\n .tickLength(this.axisTickLength())\n .low(nextLow)\n .high(nextHigh)\n .render()\n ;\n }\n\n update(domNode, element) {\n super.update(domNode, element);\n this._topAxis.tickFormat(this.tickFormat()).render();\n this._bottomAxis.tickFormat(this.tickFormat()).render();\n this._gantt.render();\n }\n\n exit(domNode, element) {\n this._bottomAxis.target(null);\n this._gantt.target(null);\n this._topAxis.target(null);\n super.exit(domNode, element);\n }\n\n columns(): string[];\n columns(_: string[]): this;\n columns(_?: string[]): this | string[] {\n const retVal = super.columns.apply(this, arguments);\n if (arguments.length > 0) {\n this._gantt.columns(_);\n }\n return retVal;\n }\n\n data(): IAxisGanttData[];\n data(_: IAxisGanttData[]): this;\n data(_?: IAxisGanttData[]): this | IAxisGanttData[] {\n const retVal = super.data.apply(this, arguments);\n if (arguments.length > 0) {\n const ganttData: any[] = this.data().map(n => {\n const ret = [...n];\n ret[1] = isNaN(n[1] as any) ? new Date(n[1]).getTime() : Number(n[1]);\n ret[2] = isNaN(n[2] as any) ? new Date(n[2]).getTime() : Number(n[2]);\n return ret;\n });\n this._gantt._minStart = Math.min(...ganttData.map(n => n[1])) ?? 0;\n this._gantt._maxEnd = Math.max(...ganttData.map(n => n[2])) ?? 1;\n this._gantt.data(ganttData);\n }\n return retVal;\n }\n\n resize(_size?: { width: number, height: number }) {\n const retVal = super.resize.apply(this, arguments);\n\n if (this._topAxisElement) {\n this.resizeWrappers();\n }\n\n return retVal;\n }\n\n click(row, col, sel) {\n\n }\n\n dblclick(row, col, sel) {\n\n }\n\n tooltip() {\n return this._gantt._tooltip;\n }\n}\nReactAxisGantt.prototype._class += \" timeline_ReactAxisGantt\";\n\nexport interface ReactAxisGantt {\n tickFormat(): string;\n tickFormat(_: string): this;\n tickFormat_exists(): boolean;\n overlapTolerence(): number;\n overlapTolerence(_: number): this;\n smallestRangeWidth(): number;\n smallestRangeWidth(_: number): this;\n scaleMode(): boolean;\n scaleMode(_: boolean): this;\n fontSize(): number;\n fontSize(_: number): this;\n fontFamily(): string;\n fontFamily(_: string): this;\n strokeWidth(): number;\n strokeWidth(_: number): this;\n stroke(): string;\n stroke(_: string): this;\n cornerRadius(): number;\n cornerRadius(_: number): this;\n axisFontSize(): number;\n axisFontSize(_: number): this;\n axisFontFamily(): string;\n axisFontFamily(_: string): this;\n axisTickLength(): number;\n axisTickLength(_: number): this;\n axisHeight(): number;\n axisHeight(_: number): this;\n titleColumn(): string;\n titleColumn(_: string): this;\n startDateColumn(): string;\n startDateColumn(_: string): this;\n endDateColumn(): string;\n endDateColumn(_: string): this;\n iconColumn(): string;\n iconColumn(_: string): this;\n colorColumn(): string;\n colorColumn(_: string): this;\n bucketColumn(): string;\n bucketColumn(_: string): this;\n maxZoom(): number;\n maxZoom(_: number): this;\n}\nReactAxisGantt.prototype.publish(\"tickFormat\", null, \"string\", \"Format rule applied to axis tick labels\", undefined, { optional: true });\nReactAxisGantt.prototype.publish(\"axisHeight\", 22, \"number\", \"Height of axes (pixels)\");\nReactAxisGantt.prototype.publish(\"overlapTolerence\", 2, \"number\", \"overlapTolerence\");\nReactAxisGantt.prototype.publish(\"smallestRangeWidth\", 10, \"number\", \"Width of the shortest range (pixels)\");\nReactAxisGantt.prototype.publish(\"axisFontSize\", null, \"number\", \"Font size of axis tick labels\");\nReactAxisGantt.prototype.publish(\"axisFontFamily\", null, \"string\", \"Font family of axis tick labels\");\nReactAxisGantt.prototype.publish(\"axisTickLength\", null, \"number\", \"Length of axis ticks\");\nReactAxisGantt.prototype.publishProxy(\"gutter\", \"_gantt\");\nReactAxisGantt.prototype.publishProxy(\"renderMode\", \"_gantt\");\nReactAxisGantt.prototype.publishProxy(\"strokeWidth\", \"_gantt\");\nReactAxisGantt.prototype.publishProxy(\"fontSize\", \"_gantt\");\nReactAxisGantt.prototype.publishProxy(\"fontFamily\", \"_gantt\");\nReactAxisGantt.prototype.publishProxy(\"stroke\", \"_gantt\");\nReactAxisGantt.prototype.publishProxy(\"cornerRadius\", \"_gantt\");\nReactAxisGantt.prototype.publishProxy(\"titleColumn\", \"_gantt\");\nReactAxisGantt.prototype.publishProxy(\"startDateColumn\", \"_gantt\");\nReactAxisGantt.prototype.publishProxy(\"endDateColumn\", \"_gantt\");\nReactAxisGantt.prototype.publishProxy(\"iconColumn\", \"_gantt\");\nReactAxisGantt.prototype.publishProxy(\"colorColumn\", \"_gantt\");\nReactAxisGantt.prototype.publishProxy(\"bucketColumn\", \"_gantt\");\nReactAxisGantt.prototype.publishProxy(\"maxZoom\", \"_gantt\");\nReactAxisGantt.prototype.publishProxy(\"bucketHeight\", \"_gantt\");\n", "import { min as d3Min, max as d3Max } from \"d3-array\";\nimport { Axis } from \"@hpcc-js/chart\";\nimport { Border2 } from \"@hpcc-js/layout\";\nimport { React } from \"@hpcc-js/react\";\nimport { ReactGantt } from \"./ReactGantt.ts\";\nimport { IAxisGanttData } from \"./ReactAxisGantt.ts\";\n\nexport class ReactAxisGanttSeries extends Border2 {\n\n protected _topAxis: Axis = new Axis(\"origin\")\n .orientation(\"top\")\n .type(\"linear\")\n .shrinkToFit(\"none\")\n .overlapMode(\"hide\")\n .extend(0)\n .tickFormat(\"d\")\n ;\n protected _gantt: ReactGantt = new ReactGantt(\"origin\")\n .stroke(\"#000000\")\n .fitHeightToContent(true)\n ;\n protected _bottomAxis: Axis = new Axis(\"origin\")\n .orientation(\"bottom\")\n .type(\"linear\")\n .shrinkToFit(\"none\")\n .overlapMode(\"hide\")\n .extend(0)\n .tickFormat(\"d\")\n ;\n\n protected _topAxisElement;\n protected _contentElement;\n protected _bottomAxisElement;\n protected _topRect;\n protected _contentRect;\n protected _bottomRect;\n\n constructor() {\n super();\n this.centerOverflowX_default(\"hidden\");\n this.centerOverflowY_default(\"auto\");\n }\n\n selection(_: any[]): this;\n selection(): any[];\n selection(_?: any[]): any[] | this {\n if (!arguments.length) return this._gantt.selection();\n this._gantt.selection(_);\n return this;\n }\n\n rangeRenderer(): React.FunctionComponent;\n rangeRenderer(_: React.FunctionComponent): this;\n rangeRenderer(_?: React.FunctionComponent): this | React.FunctionComponent {\n const ret = this._gantt.rangeRenderer.apply(this._gantt, arguments);\n if (!arguments.length) return ret;\n return this;\n }\n\n resizeWrappers() {\n\n const w = this.width();\n const h = this.height();\n\n const axisHeight = this.axisHeight(); //TODO: Dynamic scaling to allow for small resolutions?\n const contentHeight = (h - (axisHeight * 2));\n\n this.bottomHeight(axisHeight);\n\n this._topWA.resize({\n width: w,\n height: axisHeight\n });\n this._centerWA.resize({\n width: w,\n height: contentHeight\n });\n this._bottomWA.resize({\n width: w,\n height: axisHeight\n });\n this.top().render();\n this.bottom().render();\n this.center().render();\n }\n\n enter(domNode, element) {\n super.enter(domNode, element);\n\n this._gantt.click = (row, col, sel) => {\n this.click(row, col, sel);\n };\n\n this._gantt.dblclick = (row, col, sel) => {\n this.dblclick(row, col, sel);\n };\n\n this.top(this._topAxis);\n this.center(this._gantt);\n this.bottom(this._bottomAxis);\n\n this.resizeWrappers();\n\n this._gantt.zoomedHook = (transform) => {\n this.onzoom(transform);\n };\n }\n\n onzoom(transform) {\n const w = this.width();\n const low = this._gantt._minStart;\n const high = this._gantt._maxEnd;\n const range = high - low;\n const wpp = range / w;\n const nextLow = Math.floor(low - (wpp * (transform.x / transform.k)));\n const nextHigh = Math.ceil((range / transform.k) + nextLow);\n\n this._topAxis\n .fontFamily(this.axisFontFamily())\n .fontSize(this.axisFontSize())\n .tickLength(this.axisTickLength())\n .low(nextLow)\n .high(nextHigh)\n .lazyRender()\n ;\n this._bottomAxis\n .fontFamily(this.axisFontFamily())\n .fontSize(this.axisFontSize())\n .tickLength(this.axisTickLength())\n .low(nextLow)\n .high(nextHigh)\n .lazyRender()\n ;\n }\n\n update(domNode, element) {\n super.update(domNode, element);\n this._topAxis.tickFormat(this.tickFormat()).render();\n this._bottomAxis.tickFormat(this.tickFormat()).render();\n this._gantt.render();\n }\n\n columns(): string[];\n columns(_: string[]): this;\n columns(_?: string[]): this | string[] {\n const retVal = super.columns.apply(this, arguments);\n if (arguments.length > 0) {\n this._gantt.columns(_);\n }\n return retVal;\n }\n\n data(): IAxisGanttData[];\n data(_: IAxisGanttData[]): this;\n data(_?: IAxisGanttData[]): this | IAxisGanttData[] {\n const retVal = super.data.apply(this, arguments);\n if (arguments.length > 0) {\n const ganttData: any[] = this.data().map(n => {\n const ret = [...n];\n ret[1] = isNaN(n[1] as any) ? new Date(n[1]).getTime() : Number(n[1]);\n ret[2] = isNaN(n[2] as any) ? new Date(n[2]).getTime() : Number(n[2]);\n return ret;\n });\n\n this._gantt._minStart = d3Min(ganttData, n => n[1]);\n this._gantt._maxEnd = d3Max(ganttData, n => n[2]);\n this._gantt.data(ganttData);\n }\n return retVal;\n }\n\n resize(_size?: { width: number, height: number }) {\n const retVal = super.resize.apply(this, arguments);\n\n if (this._topAxisElement) {\n this.resizeWrappers();\n }\n\n return retVal;\n }\n\n click(row, col, sel) {\n\n }\n\n dblclick(row, col, sel) {\n\n }\n\n tooltip() {\n return this._gantt._tooltip;\n }\n}\nReactAxisGanttSeries.prototype._class += \" timeline_ReactAxisGanttSeries\";\n\nexport interface ReactAxisGanttSeries {\n tickFormat(): string;\n tickFormat(_: string): this;\n tickFormat_exists(): boolean;\n overlapTolerence(): number;\n overlapTolerence(_: number): this;\n smallestRangeWidth(): number;\n smallestRangeWidth(_: number): this;\n scaleMode(): boolean;\n scaleMode(_: boolean): this;\n fontSize(): number;\n fontSize(_: number): this;\n fontFamily(): string;\n fontFamily(_: string): this;\n strokeWidth(): number;\n strokeWidth(_: number): this;\n stroke(): string;\n stroke(_: string): this;\n cornerRadius(): number;\n cornerRadius(_: number): this;\n axisFontSize(): number;\n axisFontSize(_: number): this;\n axisFontFamily(): string;\n axisFontFamily(_: string): this;\n axisTickLength(): number;\n axisTickLength(_: number): this;\n axisHeight(): number;\n axisHeight(_: number): this;\n titleColumn(): string;\n titleColumn(_: string): this;\n startDateColumn(): string;\n startDateColumn(_: string): this;\n endDateColumn(): string;\n endDateColumn(_: string): this;\n iconColumn(): string;\n iconColumn(_: string): this;\n colorColumn(): string;\n colorColumn(_: string): this;\n seriesColumn(): string;\n seriesColumn(_: string): this;\n bucketColumn(): string;\n bucketColumn(_: string): this;\n maxZoom(): number;\n maxZoom(_: number): this;\n}\nReactAxisGanttSeries.prototype.publish(\"tickFormat\", null, \"string\", \"Format rule applied to axis tick labels\", undefined, { optional: true });\nReactAxisGanttSeries.prototype.publish(\"axisHeight\", 22, \"number\", \"Height of axes (pixels)\");\nReactAxisGanttSeries.prototype.publish(\"overlapTolerence\", 2, \"number\", \"overlapTolerence\");\nReactAxisGanttSeries.prototype.publish(\"smallestRangeWidth\", 10, \"number\", \"Width of the shortest range (pixels)\");\nReactAxisGanttSeries.prototype.publish(\"axisFontSize\", null, \"number\", \"Font size of axis tick labels\");\nReactAxisGanttSeries.prototype.publish(\"axisFontFamily\", null, \"string\", \"Font family of axis tick labels\");\nReactAxisGanttSeries.prototype.publish(\"axisTickLength\", null, \"number\", \"Length of axis ticks\");\nReactAxisGanttSeries.prototype.publishProxy(\"gutter\", \"_gantt\");\nReactAxisGanttSeries.prototype.publishProxy(\"renderMode\", \"_gantt\");\nReactAxisGanttSeries.prototype.publishProxy(\"strokeWidth\", \"_gantt\");\nReactAxisGanttSeries.prototype.publishProxy(\"fontSize\", \"_gantt\");\nReactAxisGanttSeries.prototype.publishProxy(\"fontFamily\", \"_gantt\");\nReactAxisGanttSeries.prototype.publishProxy(\"stroke\", \"_gantt\");\nReactAxisGanttSeries.prototype.publishProxy(\"cornerRadius\", \"_gantt\");\nReactAxisGanttSeries.prototype.publishProxy(\"titleColumn\", \"_gantt\");\nReactAxisGanttSeries.prototype.publishProxy(\"startDateColumn\", \"_gantt\");\nReactAxisGanttSeries.prototype.publishProxy(\"endDateColumn\", \"_gantt\");\nReactAxisGanttSeries.prototype.publishProxy(\"iconColumn\", \"_gantt\");\nReactAxisGanttSeries.prototype.publishProxy(\"colorColumn\", \"_gantt\");\nReactAxisGanttSeries.prototype.publishProxy(\"seriesColumn\", \"_gantt\");\nReactAxisGanttSeries.prototype.publishProxy(\"bucketColumn\", \"_gantt\");\nReactAxisGanttSeries.prototype.publishProxy(\"maxZoom\", \"_gantt\");\nReactAxisGanttSeries.prototype.publishProxy(\"evenSeriesBackground\", \"_gantt\");\nReactAxisGanttSeries.prototype.publishProxy(\"oddSeriesBackground\", \"_gantt\");\nReactAxisGanttSeries.prototype.publishProxy(\"bucketHeight\", \"_gantt\");\n", "import { timeFormat as d3TimeFormat, timeParse as d3TimeParse } from \"d3-time-format\";\nimport { ReactAxisGantt } from \"./ReactAxisGantt.ts\";\n\nexport class ReactTimeline extends ReactAxisGantt {\n\n protected _axisLabelFormatter;//TODO: add a type to this? d3 time formatting function type?\n\n constructor() {\n super();\n this._drawStartPos = \"origin\";\n this._topAxis.type(\"time\");\n this._bottomAxis.type(\"time\");\n\n this.tooltipHTML((d: any) => {\n const parser = d3TimeParse(\"%Q\");\n const startTime = parser(d[1]);\n const endTime = parser(d[2]);\n\n const formatter = d3TimeFormat(this.tooltipTimeFormat());\n return `<div style=\"text-align:center;\">${d[0]}<br/><br/>${formatter(startTime)} -> ${formatter(endTime)}</div>`;\n });\n }\n\n update(domNode, element) {\n super.update(domNode, element);\n\n if (this.timePattern_exists()) {\n\n let minTimestamp = Infinity;\n let maxTimestamp = -Infinity;\n let lowDateStr = \"\";\n let highDateStr = \"\";\n this.data().map(n => {\n const start = new Date(n[1]).getTime();\n const end = new Date(n[2]).getTime();\n if (minTimestamp > start) {\n minTimestamp = start;\n lowDateStr = \"\" + n[1];\n }\n if (maxTimestamp < end) {\n maxTimestamp = end;\n highDateStr = \"\" + n[2];\n }\n });\n this._topAxis\n .type(\"time\")\n .timePattern(this.timePattern())\n .overlapMode(\"none\")\n .tickFormat(this._axisLabelFormatter)\n .low(lowDateStr)\n .high(highDateStr)\n ;\n this._bottomAxis\n .type(\"time\")\n .timePattern(this.timePattern())\n .overlapMode(\"none\")\n .tickFormat(this._axisLabelFormatter)\n .low(lowDateStr)\n .high(highDateStr)\n ;\n this._gantt._minStart = minTimestamp;\n this._gantt._maxEnd = maxTimestamp;\n }\n }\n\n tooltipHTML(callback) {\n this._tooltipHTML = callback;\n this.tooltip().tooltipHTML(this._tooltipHTML);\n return this;\n }\n\n parseAxisValue(v) {\n const parseTime = d3TimeParse(\"%Q\");\n const parsedTime = parseTime(v);\n\n const formatTime = d3TimeFormat(this.timePattern());\n return formatTime(parsedTime);\n }\n\n onzoom(transform) {\n\n const w = this.width();\n const low = this._gantt._minStart;\n const high = this._gantt._maxEnd;\n const range = high - low;\n const wpp = range / w;\n const nextLow = Math.floor(low - (wpp * (transform.x / transform.k)));\n const nextHigh = Math.ceil((range / transform.k) + nextLow);\n\n this._topAxis\n .low(this.parseAxisValue(nextLow))\n .high(this.parseAxisValue(nextHigh))\n .render()\n ;\n this._bottomAxis\n .low(this.parseAxisValue(nextLow))\n .high(this.parseAxisValue(nextHigh))\n .render()\n ;\n }\n}\nReactTimeline.prototype._class += \" timeline_ReactTimeline\";\n\nexport interface ReactTimeline {\n _tooltipHTML(_): string;\n\n timePattern(): string;\n timePattern(_: string): this;\n timePattern_exists(): boolean;\n tooltipTimeFormat(): string;\n tooltipTimeFormat(_: string): this;\n}\nReactTimeline.prototype.publish(\"timePattern\", \"%Y-%m-%d\", \"string\", \"Time pattern used for parsing datetime strings on each data row\", null, { optional: true });\nReactTimeline.prototype.publish(\"tooltipTimeFormat\", \"%Y-%m-%d\", \"string\", \"Time format used in the default html tooltip\");\n\n", "import { timeFormat as d3TimeFormat, timeParse as d3TimeParse } from \"d3-time-format\";\nimport { ReactAxisGanttSeries } from \"./ReactAxisGanttSeries.ts\";\n\nconst parseTime = d3TimeParse(\"%Q\");\nexport class ReactTimelineSeries extends ReactAxisGanttSeries {\n\n protected _axisLabelFormatter;//TODO: add a type to this? d3 time formatting function type?\n\n constructor() {\n super();\n this._topAxis.type(\"time\");\n this._bottomAxis.type(\"time\");\n\n this.tooltipHTML((d: any) => {\n const startTime = parseTime(d[1]);\n const endTime = parseTime(d[2]);\n\n const formatter = d3TimeFormat(this.tooltipTimeFormat());\n return `<div style=\"text-align:center;\">${d[0]}<br/><br/>${formatter(startTime)} -> ${formatter(endTime)}</div>`;\n });\n }\n\n update(domNode, element) {\n super.update(domNode, element);\n\n if (this.timePattern_exists()) {\n\n let minTimestamp = Infinity;\n let maxTimestamp = -Infinity;\n let lowDateStr = \"\";\n let highDateStr = \"\";\n this.data().forEach(n => {\n const start = new Date(n[1]).getTime();\n const end = new Date(n[2]).getTime();\n if (minTimestamp > start) {\n minTimestamp = start;\n lowDateStr = \"\" + n[1];\n }\n if (maxTimestamp < end) {\n maxTimestamp = end;\n highDateStr = \"\" + n[2];\n }\n });\n this._topAxis\n .type(\"time\")\n .timePattern(this.timePattern())\n .overlapMode(\"none\")\n .tickFormat(this._axisLabelFormatter)\n .low(lowDateStr)\n .high(highDateStr)\n ;\n this._bottomAxis\n .type(\"time\")\n .timePattern(this.timePattern())\n .overlapMode(\"none\")\n .tickFormat(this._axisLabelFormatter)\n .low(lowDateStr)\n .high(highDateStr)\n ;\n this._gantt._minStart = minTimestamp;\n this._gantt._maxEnd = maxTimestamp;\n }\n }\n\n tooltipHTML(callback) {\n this._tooltipHTML = callback;\n this.tooltip().tooltipHTML(this._tooltipHTML);\n return this;\n }\n\n parseAxisValue(v) {\n const parsedTime = parseTime(v);\n\n const formatTime = d3TimeFormat(this.timePattern());\n return formatTime(parsedTime);\n }\n\n onzoom(transform) {\n\n const w = this.width();\n const low = this._gantt._minStart;\n const high = this._gantt._maxEnd;\n const range = high - low;\n const wpp = range / w;\n const nextLow = Math.floor(low - (wpp * (transform.x / transform.k)));\n const nextHigh = Math.ceil((range / transform.k) + nextLow);\n\n this._topAxis\n .low(this.parseAxisValue(nextLow))\n .high(this.parseAxisValue(nextHigh))\n .render()\n ;\n this._bottomAxis\n .low(this.parseAxisValue(nextLow))\n .high(this.parseAxisValue(nextHigh))\n .render()\n ;\n }\n\n _tooltipHTML: (_) => string;\n}\nReactTimelineSeries.prototype._class += \" timeline_ReactTimelineSeries\";\n\nexport interface ReactTimelineSeries {\n timePattern(): string;\n timePattern(_: string): this;\n timePattern_exists(): boolean;\n tooltipTimeFormat(): string;\n tooltipTimeFormat(_: string): this;\n}\nReactTimelineSeries.prototype.publish(\"timePattern\", \"%Y-%m-%d\", \"string\", \"Time pattern used for parsing datetime strings on each data row\", null, { optional: true });\nReactTimelineSeries.prototype.publish(\"tooltipTimeFormat\", \"%Y-%m-%d\", \"string\", \"Time format used in the default html tooltip\");\n\n"],
|
|
5
|
-
"mappings": "+EAAO,IAAMA,GAAW,oBACXC,GAAc,QACdC,GAAgB,QCF7B,OAAS,YAAAC,MAAgB,eACzB,OAAS,QAAAC,MAAY,iBACrB,OAAS,WAAAC,EAAS,aAAAC,EAAW,cAAAC,EAAY,SAASC,EAAS,UAAUC,EAAU,aAAAC,EAAW,WAAAC,MAAe,kBACzG,OAAS,UAAUC,MAAgB,kBACnC,OAAS,aAAaC,MAAmB,kBACzC,OAAS,cAAcC,EAAc,aAAaC,MAAmB,kBACrE,OAAS,QAAQC,GAAQ,gBAAgBC,OAAsB,mBCN9D,UAAU,CACH,GAAI,CAAC,SAAS,eAAe,UAAU,EAAG,CACtC,IAAIC,EAAI,SAAS,cAAc,OAAO,EACtCA,EAAE,GAAK,WACPA,EAAE,YAAc;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GA+BhB,SAAS,KAAK,YAAYA,CAAC,CAC/B,CACJ,GAAG,ED3BA,IAAMC,EAAN,cAAwBC,CAAU,CAVzC,MAUyC,CAAAC,EAAA,kBAC3B,OACA,OACA,cACA,MACA,cACA,WACA,eACA,WACA,cACF,UAAYC,EAAoB,EAChC,eAAiBA,EAAmB,EACpC,iBACA,WAEE,WACA,WAAa,EACb,eAAiB,EACjB,aAAe,EACf,UAAY,GACZ,WAAa,GACb,aAAe,GAEzB,aAAc,CACV,MAAM,EACNC,EAAS,KAAK,IAAI,EAClBC,EAAQ,qBAAqB,KAAK,IAAI,EAEtC,KAAK,cAAgB,SACrB,KAAK,YAAaC,GAAW,WAAWA,EAAE,KAAK,UAAU,CAAC,gBAAgB,KAAK,iBAAiB,KAAK,OAAO,MAAMA,EAAE,KAAK,cAAc,CAAC,CAAC,CAAC,OAAO,KAAK,iBAAiB,KAAK,OAAO,MAAMA,EAAE,KAAK,YAAY,CAAC,CAAC,CAAC,EAAE,EAEjN,KAAK,OAAS,IAAIC,EAAK,EAClB,KAAK,MAAM,EAEhB,KAAK,OAAS,IAAIA,EAAK,EAClB,KAAK,MAAM,EAEhB,KAAK,cAAgBC,EAAY,EAC5B,aAAa,EAAG,EAChB,aAAa,EAAG,CAEzB,CAEA,cAAwB,CACpB,OAAO,KAAK,YAAY,IAAM,YAClC,CAEA,YAAa,CACT,IAAMC,EAAO,CAAC,GAAG,KAAK,KAAK,EAAE,IAAIH,GAAKA,EAAE,KAAK,cAAc,CAAC,EAAG,GAAG,KAAK,KAAK,EAAE,OAAOA,GAAK,CAAC,CAACA,EAAE,KAAK,YAAY,CAAC,EAAE,IAAIA,GAAKA,EAAE,KAAK,YAAY,CAAC,CAAC,EAChJ,OAAOI,EAASD,CAAI,CACxB,CAEA,QAAS,CACL,IAAME,EAAS,KAAK,WAAa,CAAC,KAAK,WAAW,CAAC,EAAG,KAAK,WAAW,CAAC,CAAC,EAAI,KAAK,WAAW,EAC5F,GAAIA,EAAO,CAAC,IAAM,QAAaA,EAAO,CAAC,IAAM,SACrCA,EAAO,CAAC,IAAMA,EAAO,CAAC,GAAK,KAAK,mBAAmB,GAAG,CACtD,IAAMC,EAASC,EAAY,KAAK,YAAY,CAAC,EACvCC,EAAYC,EAAa,KAAK,YAAY,CAAC,EAC3CC,EAAQJ,EAAOD,EAAO,CAAC,CAAC,EACxBM,EAAQL,EAAOD,EAAO,CAAC,CAAC,EAC9B,GAAIA,EAAO,CAAC,IAAMA,EAAO,CAAC,EACtBA,EAAO,CAAC,EAAIG,EAAU,IAAI,KAAKE,EAAM,YAAYA,EAAM,YAAY,EAAI,CAAC,CAAC,CAAC,EAC1EL,EAAO,CAAC,EAAIG,EAAU,IAAI,KAAKE,EAAM,YAAYA,EAAM,YAAY,EAAI,CAAC,CAAC,CAAC,MACvE,CACH,IAAME,EAAQF,EAAM,QAAQ,EACtBG,EAAWF,EAAM,QAAQ,EAAIC,EACnCP,EAAO,CAAC,EAAIG,EAAUE,CAAK,EAC3BL,EAAO,CAAC,EAAIG,EAAU,IAAI,KAAKI,EAASC,EAAW,CAAE,CAAC,CAC1D,CACJ,CAEJ,OAAOR,CACX,CAEA,aAAaL,EAAG,CACZ,GAAI,OAAO,KAAK,WAAWA,EAAE,KAAK,cAAc,CAAC,EAAM,IACnD,OAAO,KAAK,WAAWA,EAAE,KAAK,cAAc,CAAC,EAEjD,IAAMc,EAAM,KAAK,OAAO,SAASd,EAAE,KAAK,cAAc,CAAC,EACvD,YAAK,WAAWA,EAAE,KAAK,cAAc,CAAC,EAAIc,EACnCA,CACX,CAEA,WAAWd,EAAG,CACV,GAAI,OAAO,KAAK,WAAWA,EAAE,KAAK,YAAY,CAAC,EAAM,IACjD,OAAO,KAAK,WAAWA,EAAE,KAAK,YAAY,CAAC,EAE/C,IAAMc,EAAM,KAAK,OAAO,SAASd,EAAE,KAAK,YAAY,CAAC,EACrD,YAAK,WAAWA,EAAE,KAAK,YAAY,CAAC,EAAIc,EACjCA,CACX,CAEA,UAAUd,EAAG,CACT,OAAO,KAAK,WAAWA,CAAC,EAAI,KAAK,aAAaA,CAAC,CACnD,CAEQ,UACR,WAAY,CAER,KAAK,MAAM,UAAU,KAAK,QAAQ,EAAGe,GAAe,UAAU,EAAG,KAAK,aAAa,EAAI,EAAI,KAAK,OAAO,CAAC,CAAC,CAC7G,CAEA,QAAS,CACL,KAAK,UAAYC,EAAQ,EAAE,UAC3B,KAAK,OAAO,CAChB,CAEQ,WACR,MAAMC,EAASC,EAAS,CACpB,MAAM,MAAMD,EAASC,CAAO,EAC5B,KAAK,MAAQC,GAAO,EACf,YAAY,CAAC,EAAG,KAAK,QAAQ,CAAC,CAAC,EAC/B,GAAG,OAAQ,IAAM,CACd,KAAK,OAAO,CAChB,CAAC,EAGL,KAAK,WAAaD,EAAQ,OAAO,MAAM,EAClC,KAAK,OAAQ,OAAO,EACpB,KAAK,UAAW,CAAC,EACjB,GAAG,WAAY,IAAM,CAClBF,EAAQ,EAAE,gBAAgB,EAC1B,OAAO,KAAK,WACZ,KAAK,UAAU,CACnB,CAAC,EAEL,KAAK,cAAgBE,EAAQ,OAAO,GAAG,EAAE,KAAK,QAAS,eAAe,EACtE,KAAK,WAAaA,EAAQ,OAAO,GAAG,EAAE,KAAK,QAAS,YAAY,EAChE,KAAK,eAAiBA,EAAQ,OAAO,GAAG,EAAE,KAAK,QAAS,gBAAgB,EACxE,KAAK,WAAaA,EAAQ,OAAO,GAAG,EAAE,KAAK,QAAS,YAAY,EAChE,KAAK,cAAgBA,EAAQ,OAAO,GAAG,EAAE,KAAK,QAAS,eAAe,EACtE,KAAK,OACA,OAAO,KAAK,WAAW,KAAK,CAAC,EAC7B,WAAW,KAAK,WAAW,CAAC,EAC5B,YAAY,KAAK,WAAW,OAAO,GAAG,EAAE,KAAK,CAAC,EAC9C,YAAY,MAAM,EAClB,YAAY,KAAK,kBAAkB,EAAI,UAAY,MAAM,EACzD,OAAO,EAAG,EAEf,KAAK,OACA,OAAO,KAAK,WAAW,KAAK,CAAC,EAC7B,WAAW,KAAK,WAAW,CAAC,EAC5B,YAAY,KAAK,WAAW,OAAO,GAAG,EAAE,KAAK,CAAC,EAC9C,YAAY,MAAM,EAClB,YAAY,KAAK,kBAAkB,EAAI,UAAY,MAAM,EACzD,OAAO,EAAG,EAGfA,EAAQ,KAAK,KAAK,KAAK,EACvB,KAAK,WAAW,cAAc,KAAK,cAAc,CACrD,CAEQ,kBACR,OAAOD,EAASC,EAAS,CAYrB,GAXA,MAAM,OAAOD,EAASC,CAAO,EAE7B,KAAK,WAAa,CAAC,EAEnB,KAAK,WAAa,KAAK,YAAY,IAAM,KAAO,KAAK,QAAQ,EAAE,QAAQ,KAAK,YAAY,CAAC,EAAI,KAAK,WAClG,KAAK,eAAiB,KAAK,gBAAgB,IAAM,KAAO,KAAK,QAAQ,EAAE,QAAQ,KAAK,gBAAgB,CAAC,EAAI,KAAK,eAC9G,KAAK,aAAe,KAAK,cAAc,IAAM,KAAO,KAAK,QAAQ,EAAE,QAAQ,KAAK,cAAc,CAAC,EAAI,KAAK,aACxG,KAAK,UAAY,KAAK,WAAW,IAAM,KAAO,KAAK,QAAQ,EAAE,QAAQ,KAAK,WAAW,CAAC,EAAI,KAAK,UAC/F,KAAK,WAAa,KAAK,YAAY,IAAM,KAAO,KAAK,QAAQ,EAAE,QAAQ,KAAK,YAAY,CAAC,EAAI,KAAK,WAClG,KAAK,aAAe,KAAK,cAAc,IAAM,KAAO,KAAK,QAAQ,EAAE,QAAQ,KAAK,cAAc,CAAC,EAAI,KAAK,aAEpG,KAAK,oBAAsB,KAAK,aAAa,EAAG,CAChD,KAAK,kBAAoB,KAAK,aAAa,EAC3C,KAAK,UAAU,EACf,MACJ,CAEA,KAAK,iBAAmBT,EAAa,KAAK,kBAAkB,CAAC,EAE7D,IAAMW,EAAQ,KAAK,MAAM,EACnBC,EAAS,KAAK,OAAO,EAE3B,KAAK,WACA,KAAK,IAAK,CAAC,EACX,KAAK,IAAK,CAAC,EACX,KAAK,QAASD,CAAK,EACnB,KAAK,SAAUC,CAAM,EAG1B,IAAMhB,EAAS,KAAK,OAAO,EAyB3B,GAxBA,KAAK,OACA,EAAEe,EAAQ,CAAC,EACX,YAAY,KAAK,aAAa,EAAI,MAAQ,MAAM,EAChD,QAAQ,CAAC,KAAK,aAAa,CAAC,EAC5B,YAAY,KAAK,YAAY,CAAC,EAC9B,MAAMA,EAAQ,CAAC,EACf,IAAIf,EAAO,CAAC,CAAC,EACb,KAAKA,EAAO,CAAC,CAAC,EACd,YAAY,EAGjB,KAAK,OACA,EAAEe,EAAQ,CAAC,EACX,EAAEC,EAAS,CAAC,EACZ,YAAY,KAAK,aAAa,EAAI,SAAW,OAAO,EACpD,QAAQ,CAAC,KAAK,aAAa,CAAC,EAC5B,YAAY,KAAK,YAAY,CAAC,EAC9B,MAAMD,EAAQ,CAAC,EACf,OAAOC,CAAM,EACb,IAAIhB,EAAO,CAAC,CAAC,EACb,KAAKA,EAAO,CAAC,CAAC,EACd,YAAY,EAGb,KAAK,UAAW,CAChB,IAAIiB,EACAC,EACA,KAAK,aAAa,GAClBD,EAAM,KAAK,OAAO,YAAY,KAAK,OAAO,OAAO,KAAK,UAAU,QAAQ,CAAC,CAAC,CAAC,EAC3EC,EAAK,KAAK,OAAO,YAAY,KAAK,OAAO,OAAO,KAAK,UAAU,QAAQH,EAAQ,CAAC,CAAC,CAAC,IAElFE,EAAM,KAAK,OAAO,YAAY,KAAK,OAAO,OAAO,CAAE,KAAK,UAAU,QAAQ,CAAC,CAAC,CAAC,EAC7EC,EAAK,KAAK,OAAO,YAAY,KAAK,OAAO,OAAO,CAAE,KAAK,UAAU,QAAQF,EAAS,CAAC,CAAC,CAAC,GAEzF,KAAK,OACA,IAAIC,CAAG,EACP,KAAKC,CAAE,EACP,YAAY,EAEjB,KAAK,OACA,IAAID,CAAG,EACP,KAAKC,CAAE,EACP,YAAY,CAErB,CAEA,IAAMpB,EAAO,KAAK,KAAK,EAAE,KAAK,KAAK,aAAa,EAAI,CAACqB,EAAGC,IAAM,CAC1D,IAAMC,EAAS,KAAK,OAAO,SAASF,EAAE,CAAC,CAAC,EAAI,KAAK,OAAO,SAASC,EAAE,CAAC,CAAC,EACrE,OAAIC,IAAW,GACH,GAAKF,EAAE,CAAC,GAAG,cAAc,GAAKC,EAAE,CAAC,CAAC,EAEvCC,CACX,EAAI,CAACF,EAAGC,IACG,KAAK,OAAO,SAASA,EAAE,CAAC,CAAC,EAAI,KAAK,OAAO,SAASD,EAAE,CAAC,CAAC,CAChE,EACKG,EAASxB,EAAK,OAAOH,GAAK,CAACA,EAAE,KAAK,YAAY,CAAC,EAC/C4B,EAASzB,EAAK,OAAOH,GAAK,CAAC,CAACA,EAAE,KAAK,YAAY,CAAC,EAEtD,KAAK,OACA,OAAO,EAEZ,KAAK,OACA,OAAO,EAEZ,IAAM6B,EAAa,KAAK,OAAO,QAAQ,EAEnCC,EAAqB,KAAK,iBAAiBH,CAAM,EAC/CI,EAAkBF,EAAW,OAC/BG,EAAcX,EAASS,EACrBG,EAAa,KAAK,eAAiB,GAAK,KAAK,IAAI,MAAM,OAAW,KAAK,KAAK,EAAE,OAAOC,GAAO,CAAC,MAAMA,EAAI,KAAK,YAAY,CAAC,CAAC,EAAE,IAAIA,GAAOA,EAAI,KAAK,YAAY,CAAC,CAAC,EAAI,EACxK,GAAIP,EAAO,OAAS,GAAKC,EAAO,SAAW,EAAG,CAE1C,KAAK,OAAO,QAAQ,EAAK,EACzB,IAAIO,EAAWL,EAAqB,EAChCK,EAAYd,EAAS,EAAKU,IAC1BI,EAAYd,EAAS,EAAKU,GAE9B,IAAMK,EAAuBf,EAAS,EAAKc,EACrCE,GAAqBhB,EAAS,EAAKU,EAAkBI,GAAY,GACjEG,EAAiBL,IAAe,EAAIA,EAAa,EAAI,EAC3D,KAAK,cAAc,KAAK,YAAa,gBAAgBG,EAAsBE,CAAc,GAAG,EAC5F,KAAK,WAAW,KAAK,YAAa,gBAAgBD,EAAmBC,CAAc,GAAG,CAC1F,MAAWX,EAAO,SAAW,GAAKC,EAAO,OAAS,GAE9C,KAAK,OAAO,QAAQ,EAAI,EACxB,KAAK,cAAc,KAAK,YAAa,gBAAgBE,CAAkB,GAAG,EAC1E,KAAK,WAAW,KAAK,YAAa,gBAAgBA,CAAkB,GAAG,IAEvEA,GAAsBG,EACtBD,GAAeC,EAEf,KAAK,OAAO,QAAQ,EAAI,EACxB,KAAK,cAAc,KAAK,YAAa,gBAAgBH,CAAkB,GAAG,EAC1E,KAAK,WAAW,KAAK,YAAa,gBAAgBA,CAAkB,GAAG,EACvE,KAAK,eAAe,KAAK,YAAa,gBAAgBA,CAAkB,GAAG,GAE/E,KAAK,OACA,OAAO,EAEZ,IAAMS,EAAa,KAAK,OAAO,QAAQ,EAIjCC,EAA2B,CAAC,EAC5BC,EAAc,CAAC,EACrB,QAAWC,KAASd,EAAQ,CACxB,QAASe,EAAI,EAAGA,EAAIH,EAAW,OAAQ,EAAEG,EAAG,CACxC,IAAMC,EAASJ,EAAWG,CAAC,EAC3B,GAAIC,EAAO,OAAS,KAAK,iBAAiB,GAAK,KAAK,aAAaF,CAAK,EAAG,CACrED,EAAYC,CAAK,EAAIC,EACrBC,EAAO,OAAS,KAAK,WAAWF,CAAK,EACrC,KACJ,CACJ,CAEID,EAAYC,CAAK,IAAM,SACvBD,EAAYC,CAAK,EAAIF,EAAW,OAChCA,EAAW,KAAK,CACZ,OAAQ,KAAK,WAAWE,CAAK,CACjC,CAAC,EAET,CAEA,IAAMG,EAAU,KAAK,aAAa,EAAI,EAAIN,EAAW,OAAS,EAAIA,EAAW,MACvEO,EAAW,KAAK,aAAa,EAAId,EAAcH,EAAW,OAAST,EAAQS,EAAW,MAC5F,KAAK,cACA,MAAM,CAACgB,EAASC,CAAQ,CAAC,EACzB,OAAON,EAAW,IAAI,CAACO,EAAIJ,IAAMA,CAAC,CAAC,EAGpCf,EAAO,OAAS,GAChB,KAAK,kBAAkBD,EAAQC,EAAQa,EAAaT,EAAaO,EAAYV,EAAYT,CAAK,CAEtG,CAEA,iBAAiBO,EAAQ,CACrB,IAAIqB,EAAe,EACbC,EAAU,KACVC,EAAa,KAAK,cAAc,UAAU,aAAa,EAAE,KAAKvB,EAAQ3B,GAAKA,EAAE,CAAC,EAAI,IAAMA,EAAE,CAAC,CAAC,EAC5FmD,EAAqB,KAAK,qBAAqB,EAAI,KAAK,QAAQ,EAAE,QAAQ,KAAK,qBAAqB,CAAC,EAAI,GACzGC,EAAuB,KAAK,uBAAuB,EAAI,KAAK,QAAQ,EAAE,QAAQ,KAAK,uBAAuB,CAAC,EAAI,GAC/GC,EAA2B,KAAK,2BAA2B,EAAI,KAAK,QAAQ,EAAE,QAAQ,KAAK,2BAA2B,CAAC,EAAI,GAC3HC,EAAe,CAAC,EACtB,QAAWtD,KAAK2B,EAAQ,CACpB,IAAM4B,EAAO,OAAOvD,EAAEiD,EAAQ,UAAU,EAAM,IAAcjD,EAAEiD,EAAQ,UAAU,EAAIjD,EAAE,CAAC,EACvFsD,EAAaC,CAAI,EAAID,EAAaC,CAAI,EAAID,EAAaC,CAAI,EAAI,EAAI,CACvE,CACA,IAAMC,EAAc,OAAO,KAAKF,CAAY,EACtCG,EAAqBR,EAAQ,iBAAiB,EAC9CS,EAAkBR,EAAW,MAAM,EAAE,OAAO,GAAG,EAChD,KAAK,QAAS,YAAY,EAC/BQ,EAAgB,OAAO,MAAM,EACxB,KAAK,QAAS,aAAa,EAEhCA,EACK,GAAG,YAAa,SAAU1D,EAAG,CAC1B2D,EAAS,IAAI,EAAE,MAAM,CACzB,CAAC,EACA,KAAK,SAAU3D,EAAG2C,EAAG,CAClB,IAAMiB,EAAY,IAAIC,EAAU,EAC3B,OAAO,IAAI,EACX,KAAK,QAAG,EACR,oBAAoBZ,EAAQ,sBAAsB,CAAC,EACnD,qBAAqBA,EAAQ,uBAAuB,CAAC,EACrD,2BAA2BA,EAAQ,6BAA6B,CAAC,EACjE,0BAA0BA,EAAQ,6BAA6B,CAAC,EAChE,aAAa,EAAE,EACf,mBAAmB,CAAC,EACpB,cAAc,EAAE,EAChB,iBAAiB,MAAM,EACvB,oBAAoB,EAAE,EACtB,UAAUE,IAAuB,GAAK,OAASnD,EAAEmD,CAAkB,CAAC,EACpE,WAAWA,IAAuB,GAAK,OAASnD,EAAEmD,CAAkB,CAAC,EACrE,iBAAiBA,IAAuB,GAAK,OAASnD,EAAEmD,CAAkB,CAAC,EAC3E,gBAAgB,KAAK,EACrB,oBAAoBA,IAAuB,GAAK,UAAYnD,EAAEqD,CAAwB,CAAC,EACvF,sBAAsBF,IAAuB,GAAK,OAASnD,EAAEoD,CAAoB,CAAC,EAClF,aAAa,CAAC,EACd,YAAY,EAAE,EACd,WAAW,EAAE,EAElBH,EAAQ,eAAe,IAAI,KAAMW,CAAS,CAC9C,CAAC,EACA,MAAMV,CAAU,EAChB,KAAK,SAAUlD,EAAG2C,EAAG,CAClB,IAAMiB,EAAYX,EAAQ,eAAe,IAAI,IAAI,EAC3Ca,EAAS,OAAO9D,EAAEiD,EAAQ,UAAU,EAAM,IAAcjD,EAAEiD,EAAQ,UAAU,EAAIW,EAAU,MAAM,EAChGG,EAAWd,EAAQ,aAAajD,CAAC,EAAI,EACvCmC,EAAaqB,EAAY,QAAQM,CAAM,EAAIb,EAAQ,cAAc,EAAKQ,EAAsB,EAEhG,GADI,OAAOzD,EAAEiD,EAAQ,YAAY,EAAM,MAAad,GAAYnC,EAAEiD,EAAQ,YAAY,EAAIjD,EAAEiD,EAAQ,YAAY,EAAI,GAChHjD,EAAEiD,EAAQ,UAAU,IAAMW,EAAU,MAAM,GAAK5D,EAAEiD,EAAQ,cAAc,IAAMW,EAAU,YAAY,EAAG,CACtG,IAAMI,EAAoBf,EAAQ,OAAO,MAAMjD,EAAEiD,EAAQ,cAAc,CAAC,EAClEgB,EAAuBhB,EAAQ,iBAAiBe,CAAiB,EACvEJ,EACK,EAAEG,CAAQ,EACV,EAAE5B,CAAQ,EACV,oBAAoBc,EAAQ,sBAAsB,CAAC,EACnD,qBAAqBA,EAAQ,uBAAuB,CAAC,EACrD,2BAA2BA,EAAQ,6BAA6B,CAAC,EACjE,0BAA0BA,EAAQ,6BAA6B,CAAC,EAChE,KAAK,OAAOjD,EAAEiD,EAAQ,SAAS,EAAM,IAAcjD,EAAEiD,EAAQ,SAAS,EAAIW,EAAU,KAAK,CAAC,EAC1F,MAAME,CAAM,EACZ,YAAYG,CAAoB,EAChC,qBAAqB,CAE9B,MACIL,EAAU,KAAK,CAAE,EAAGG,EAAU,EAAG5B,CAAS,CAAC,EAE/C,IAAM+B,EAAcN,EAAU,WAAW,EACrCZ,EAAekB,IAAalB,EAAekB,GAE/CP,EAAS,IAAI,EAAE,UAAU,cAAc,EAClC,KAAK,KAAMI,CAAQ,EACnB,KAAK,KAAMA,CAAQ,EACnB,KAAK,KAAM,CAAC,EACZ,KAAK,KAAM5B,CAAQ,EACnB,MAAM,SAAUgB,IAAuB,GAAK,OAASnD,EAAEoD,CAAoB,CAAC,EAC5E,MAAM,eAAgB,CAAC,CAEhC,CAAC,EAELF,EAAW,KAAK,EACX,KAAK,SAAUlD,EAAG2C,EAAG,CACAM,EAAQ,eAAe,IAAI,IAAI,EACvC,OAAO,IAAI,CAEzB,CAAC,EACA,OAAO,EACZ,IAAMkB,EAAe,KAAK,IAAI,KAAK,IAAIxC,EAAO,OAAQsB,EAAQ,cAAc,CAAC,EAAIA,EAAQ,iBAAiB,CAAC,EAC3G,OAAOD,EAAemB,CAC1B,CAEA,kBAAkBxC,EAAQC,EAAQa,EAAa2B,EAAkB7B,EAAYV,EAAYT,EAAO,CAC5F,IAAM6B,EAAU,KAEVoB,EAAQ,KAAK,eAAe,UAAU,OAAO,EAAE,KAAK1C,EAAQ3B,GACvDA,EAAEiD,EAAQ,UAAU,CAC9B,EACDoB,EAAM,MAAM,EAAE,OAAO,MAAM,EACtB,KAAK,QAAS,MAAM,EACpB,MAAMA,CAAK,EACX,KAAK,KAAK,aAAa,EAAI,KAAO,KAAMrE,GAAK,KAAK,aAAaA,CAAC,EAAI,CAAC,EACrE,KAAK,KAAK,aAAa,EAAI,KAAO,KAAMA,GAAK,KAAK,aAAaA,CAAC,EAAI,CAAC,EACrE,KAAK,KAAK,aAAa,EAAI,KAAO,KAAM,KAAK,aAAa,EAAIuC,EAAW,OAASA,EAAW,KAAK,EAClG,KAAK,KAAK,aAAa,EAAI,KAAO,KAAM,KAAK,aAAa,EAAI6B,EAAmBvC,EAAW,OAAST,EAAQS,EAAW,KAAK,EAElIwC,EAAM,KAAK,EAAE,OAAO,EACpB,IAAMC,EAAU,KAAK,eAAe,UAAU,UAAU,EAAE,KAAK1C,EAAQ5B,GAAKA,EAAEiD,EAAQ,UAAU,CAAC,EACjGqB,EAAQ,MAAM,EAAE,OAAO,GAAG,EACrB,KAAK,QAAS,SAAS,EACvB,KAAK,KAAK,WAAW,MAAM,KAAK,KAAK,UAAU,CAAC,EAChD,KAAK,SAAUtE,EAAG,CACf,IAAMuE,EAAa,IAAIC,EAAW,EAC7B,OAAO,IAAI,EACX,aAAa,EAAE,EACf,mBAAmB,CAAC,EACpB,cAAc,EAAE,EAChB,WAAWvB,EAAQ,eAAe,CAAC,EACnC,iBAAiBA,EAAQ,eAAe,CAAC,EACzC,UAAUA,EAAQ,eAAe,CAAC,EAClC,gBAAgB,MAAM,EACtB,oBAAoBjD,EAAEiD,EAAQ,UAAU,CAAC,EAE9CA,EAAQ,UAAU,IAAI,KAAMsB,CAAU,EACtCtB,EAAQ,gBAAgBsB,EAAYvE,CAAC,CACzC,CAAC,EACA,GAAG,QAAS,SAAUA,EAAG,CACtBiD,EAAQ,MAAMA,EAAQ,SAASjD,CAAC,EAAG,QAASiD,EAAQ,WAAW,SAAS,IAAI,CAAC,CACjF,EAAG,EAAK,EACP,GAAG,WAAY,SAAUjD,EAAG,CACzBiD,EAAQ,WAAajD,EACrBiD,EAAQ,UAAU,EAClBA,EAAQ,SAASA,EAAQ,SAASjD,CAAC,EAAG,QAASiD,EAAQ,WAAW,SAAS,IAAI,CAAC,CACpF,EAAG,EAAI,EACN,GAAG,mBAAoB,KAAK,QAAQ,IAAI,EACxC,GAAG,oBAAqB,KAAK,QAAQ,IAAI,EACzC,MAAMqB,CAAO,EACb,KAAK,YAAatE,GAAKiD,EAAQ,aAAa,EACzC,aAAa,KAAK,aAAajD,CAAC,CAAC,KAAK,KAAK,cAAcyC,EAAYzC,CAAC,CAAC,CAAC,KACxE,aAAa,KAAK,cAAcyC,EAAYzC,CAAC,CAAC,CAAC,KAAK,KAAK,aAAaA,CAAC,CAAC,IAAI,EAC/E,KAAK,SAAUA,EAAG,CACf,IAAMyE,EAAUxB,EAAQ,UAAU,IAAI,IAAI,EACpCyB,EAAIzB,EAAQ,UAAUjD,CAAC,EAAI,EAC3B2E,EAAI1B,EAAQ,cAAc,UAAU,EAAI,EACxC2B,EAAY,KAAK,IAAI3B,EAAQ,UAAUjD,CAAC,EAAG,CAAC,EAC5C6E,EAAa,KAAK,IAAI5B,EAAQ,cAAc,UAAU,EAAG,CAAC,EAC1D6B,EAAkB,KAElBC,GADiB,EAAID,GAAmB,EACXD,EAC7BG,EAAWH,EAAaC,EACxBG,EAAWD,EACjBP,EACK,IAAIxB,EAAQ,aAAa,EAAI,CAAE,EAAAyB,EAAG,EAAAC,CAAE,EAAI,CAAE,EAAGA,EAAG,EAAGD,CAAE,CAAC,EACtD,YAAYzB,EAAQ,aAAa,EAAI4B,EAAaD,CAAS,EAC3D,WAAW3B,EAAQ,aAAa,EAAI2B,EAAYC,CAAU,EAC1D,KAAK,OAAO7E,EAAEiD,EAAQ,SAAS,EAAM,IAAcjD,EAAEiD,EAAQ,SAAS,EAAI,EAAE,EAC5E,MAAM,OAAOjD,EAAEiD,EAAQ,UAAU,EAAM,IAAcjD,EAAEiD,EAAQ,UAAU,EAAI,EAAE,EAC/E,QAAQ8B,CAAW,EACnB,aAAaE,CAAQ,EACrB,cAAcD,CAAQ,EAEvBC,EAAW,IAAML,GACjBH,EAAQ,KAAK,IAAI,EAErBxB,EAAQ,iBAAiBwB,EAASzE,EAAEiD,EAAQ,SAAS,CAAC,EACtDwB,EACK,OAAO,CAEhB,CAAC,EACLH,EAAQ,KAAK,EAAE,OAAO,CAC1B,CAEA,KAAKrD,EAASC,EAAS,CACnB,KAAK,OAAO,OAAO,IAAI,EACvB,KAAK,OAAO,OAAO,IAAI,EACvB,MAAM,KAAKD,EAASC,CAAO,CAC/B,CAGA,MAAMgB,EAAKgD,EAAKC,EAAK,CACrB,CAEA,SAASjD,EAAKgD,EAAKC,EAAK,CACxB,CAEA,gBAAgBC,EAAqBpF,EAAG,CACxC,CAEA,iBAAiBoF,EAAqBpF,EAAG,CACzC,CACJ,EACAN,EAAU,UAAU,QAAU,sBAC9BA,EAAU,UAAU,WAAWI,EAAS,SAAS,EACjDJ,EAAU,UAAU,MAAMK,EAAQ,oBAAoB,EA8DtDL,EAAU,UAAU,QAAQ,cAAe,WAAY,SAAU,aAAa,EAC9EA,EAAU,UAAU,QAAQ,aAAc,KAAM,SAAU,aAAc,OAAW,CAAE,SAAU,EAAK,CAAC,EACrGA,EAAU,UAAU,QAAQ,oBAAqB,WAAY,SAAU,mBAAmB,EAC1FA,EAAU,UAAU,QAAQ,mBAAoB,EAAG,SAAU,kBAAkB,EAC/EA,EAAU,UAAU,QAAQ,cAAe,aAAc,MAAO,cAAe,CAAC,aAAc,UAAU,CAAC,EACzGA,EAAU,UAAU,QAAQ,iBAAkB,UAAW,aAAc,gBAAgB,EACvFA,EAAU,UAAU,QAAQ,cAAe,KAAM,SAAU,aAAa,EACxEA,EAAU,UAAU,QAAQ,kBAAmB,KAAM,SAAU,iBAAiB,EAChFA,EAAU,UAAU,QAAQ,gBAAiB,KAAM,SAAU,eAAe,EAC5EA,EAAU,UAAU,QAAQ,aAAc,KAAM,SAAU,YAAY,EACtEA,EAAU,UAAU,QAAQ,cAAe,KAAM,SAAU,aAAa,EACxEA,EAAU,UAAU,QAAQ,gBAAiB,KAAM,SAAU,eAAe,EAC5EA,EAAU,UAAU,QAAQ,UAAW,GAAI,SAAU,SAAS,EAC9DA,EAAU,UAAU,QAAQ,mBAAoB,IAAK,SAAU,kBAAkB,EACjFA,EAAU,UAAU,QAAQ,gBAAiB,EAAG,SAAU,eAAe,EACzEA,EAAU,UAAU,QAAQ,uBAAwB,KAAM,SAAU,sBAAsB,EAC1FA,EAAU,UAAU,QAAQ,yBAA0B,KAAM,SAAU,wBAAwB,EAC9FA,EAAU,UAAU,QAAQ,6BAA8B,KAAM,SAAU,4BAA4B,EACtGA,EAAU,UAAU,QAAQ,wBAAyB,GAAO,UAAW,uBAAuB,EAC9FA,EAAU,UAAU,QAAQ,yBAA0B,GAAO,UAAW,wBAAwB,EAChGA,EAAU,UAAU,QAAQ,+BAAgC,GAAO,UAAW,8BAA8B,EAC5GA,EAAU,UAAU,QAAQ,+BAAgC,GAAM,UAAW,8BAA8B,EAC3GA,EAAU,UAAU,QAAQ,qBAAsB,GAAO,UAAW,sEAAsE,EEnmB1I,OAAS,WAAA2F,EAAS,UAAUC,EAAU,iBAAAC,GAAe,WAAAC,MAAe,kBACpE,OAAS,eAAAC,OAAmB,gBAC5B,OAAS,eAAeC,MAAqB,kBAC7C,OAAgB,UAAAC,GAAQ,gBAAAC,OAAoB,iBAerC,IAAMC,EAAN,cAAyBC,EAAc,CAlB9C,MAkB8C,CAAAC,EAAA,mBAEhC,WAAa,IAAIC,EAAQ,UAAU,IAAI,EAEvC,SACA,cACA,cAEA,iBACA,cACA,YACF,mBAEE,aAEH,SAEA,UACA,QAEG,WAAa,EACb,eAAiB,EACjB,aAAe,EACf,UAAY,GACZ,WAAa,GACb,YAAc,GACd,YAAc,GACd,aAAe,GAEf,MACA,MAEF,cAA+B,CACnC,aAAc,EACd,WAAY,UACZ,SAAU,GACV,KAAM,QACN,OAAQ,QACR,SAAU,QACV,aAAc,EACd,YAAa,CACjB,EAEA,YAAYC,EAAyC,SAAU,CAC3D,MAAM,EACN,KAAK,cAAgBA,EAErB,KAAK,oBAAoB,EAAK,EAE9B,KAAK,SAAW,IAAIC,GACpB,KAAK,SACA,YAAYC,GACF,mCAAmCA,EAAE,CAAC,CAAC,aAAaA,EAAE,CAAC,CAAC,UAAUA,EAAE,CAAC,CAAC,QAChF,EACL,KAAK,SACA,aAAa,EAAI,CAE1B,CAIA,UAAUC,EAAyB,CAC/B,OAAK,UAAU,QACf,KAAK,WAAW,IAAIA,CAAC,EACd,MAFuB,KAAK,WAAW,IAAI,CAGtD,CAEQ,eAA0CC,GAGlD,cAAcD,EAA6D,CACvE,OAAK,UAAU,QACf,KAAK,eAAiBA,EACf,KAAK,gBAFkB,KAAK,cAGvC,CAEA,MAAME,EAASC,EAAS,CACpB,MAAM,MAAMD,EAASC,CAAO,EAE5B,IAAMC,EAAU,KAChBD,EACK,GAAG,QAAS,SAA4BJ,EAAG,CACxCK,EAAQ,WAAW,MAAM,CAC7B,CAAC,EAEL,KAAK,SAAS,OAAOF,CAAO,CAChC,CACA,OAAOA,EAASC,EAAS,CACrB,MAAM,OAAOD,EAASC,CAAO,EAE7B,KAAK,WAAW,CAAC,IAAM,KAAK,QAAQ,CAAC,CAAC,EAEtC,KAAK,WAAa,KAAK,YAAY,IAAM,KAAO,KAAK,QAAQ,EAAE,QAAQ,KAAK,YAAY,CAAC,EAAI,KAAK,WAClG,KAAK,eAAiB,KAAK,gBAAgB,IAAM,KAAO,KAAK,QAAQ,EAAE,QAAQ,KAAK,gBAAgB,CAAC,EAAI,KAAK,eAC9G,KAAK,aAAe,KAAK,cAAc,IAAM,KAAO,KAAK,QAAQ,EAAE,QAAQ,KAAK,cAAc,CAAC,EAAI,KAAK,aACxG,KAAK,UAAY,KAAK,WAAW,IAAM,KAAO,KAAK,QAAQ,EAAE,QAAQ,KAAK,WAAW,CAAC,EAAI,KAAK,UAC/F,KAAK,WAAa,KAAK,YAAY,IAAM,KAAO,KAAK,QAAQ,EAAE,QAAQ,KAAK,YAAY,CAAC,EAAI,KAAK,WAClG,KAAK,YAAc,KAAK,aAAa,IAAM,KAAO,KAAK,QAAQ,EAAE,QAAQ,KAAK,aAAa,CAAC,EAAI,KAAK,YACrG,KAAK,YAAc,KAAK,aAAa,IAAM,KAAO,KAAK,QAAQ,EAAE,QAAQ,KAAK,aAAa,CAAC,EAAI,GAEhG,IAAMC,EAAU,KACVC,EAAI,KAAK,MAAM,EAEfC,EAAK,EACLC,EAAKF,EASX,GAPA,KAAK,cAAgBG,EAAc,EAC9B,OAAO,CAAC,KAAK,UAAW,KAAK,OAAO,CAAC,EACrC,MAAM,CAACF,EAAIC,CAAE,CAAC,EAGnB,KAAK,KAAK,EAAE,KAAK,CAACE,EAAGC,IAAMD,EAAE,CAAC,EAAIC,EAAE,CAAC,CAAC,EAElC,KAAK,YAAc,GAAI,CACvB,KAAK,YAAc,CAAC,EACpB,KAAK,cAAgB,CAAC,EACtB,KAAK,iBAAmB,CAAC,EACzB,KAAK,KAAK,EAAE,QAAQ,CAACC,EAASC,IAAY,CACtC,IAAMC,EAAYF,EAAQ,KAAK,WAAW,EACrC,KAAK,cAAcE,CAAS,IAC7B,KAAK,YAAYA,CAAS,EAAI,CAAC,EAC/B,KAAK,cAAcA,CAAS,EAAI,CAAC,GAErC,KAAK,cAAcA,CAAS,EAAE,KAAK,CAC/B,QAAAF,EACA,QAAAC,CACJ,CAAC,CACL,CAAC,EACD,IAAME,EAAS,KAAK,OAAO,EACvBC,EAAe,EACbC,EAAa,OAAO,KAAK,KAAK,aAAa,EACjDA,EAAW,QAAQH,GAAa,CAC5B,KAAK,cAAcA,CAAS,EAAE,KAAK,CAACJ,EAAGC,IAAMD,EAAE,QAAQ,CAAC,EAAIC,EAAE,QAAQ,CAAC,CAAC,EACxE,KAAK,iBAAiBG,CAAS,EAAI,KAAK,YAAY,KAAK,cAAcA,CAAS,EAAE,IAAII,GAAKA,EAAE,OAAO,EAAG,EAAG,CAAC,EAC3G,KAAK,iBAAiBJ,CAAS,EAAE,aAAe,KAAK,aAAa,EAClE,KAAK,iBAAiBA,CAAS,EAAE,aAAeE,EAChDA,IAAiB,KAAK,iBAAiBF,CAAS,EAAE,aAAe,KAAK,YAAY,EAAI,KAAK,OAAO,IAAM,KAAK,iBAAiBA,CAAS,EAAE,UAAY,GACrJ,KAAK,cAAcA,CAAS,EAAE,QAAQ,CAACI,EAAGC,IAAM,CAC5C,KAAK,YAAYL,CAAS,EAAEI,EAAE,OAAO,EAAIC,CAC7C,CAAC,CACL,CAAC,EACD,KAAK,mBAAqB,KAAK,eAAe,UAAU,oBAAoB,EACvE,KAAKF,EAAW,IAAIG,GACV,KAAK,iBAAiBA,CAAG,CACnC,CAAC,EAEN,KAAK,mBACA,KACGC,GAASA,EAAM,OAAO,MAAM,EACvB,KAAK,QAAS,mBAAmB,EACtCC,GAAUA,EACVC,GAAQA,EACH,KAAK,SAAU,EAAG,CACf,OAAO,EAAE,OACb,CAAC,EACA,OAAO,CAChB,EACC,KAAK,UAAWvB,GAAKA,EAAE,OAASA,EAAE,MAAM,OAAS,EAAI,CAAC,EACtD,KAAK,SAA6BA,EAAGmB,EAAG,CACrCK,EAAS,IAAI,EACR,KAAK,IAAK,CAAC,EACX,KAAK,IAAKxB,EAAE,aAAgBe,EAAS,CAAE,EACvC,KAAK,QAAST,CAAC,EACf,KAAK,UAAYN,EAAE,aAAee,IAAWf,EAAE,UAAY,GAAMe,CAAM,EACvE,KAAK,OAAQI,EAAI,EAAId,EAAQ,oBAAoB,EAAIA,EAAQ,qBAAqB,CAAC,CAE5F,CAAC,CACT,MACQ,KAAK,cAAgB,GACrB,KAAK,SAAW,KAAK,YAAY,KAAK,KAAK,EAAG,KAAK,eAAgB,KAAK,aAAc,KAAK,WAAW,EAEtG,KAAK,SAAW,KAAK,YAAY,KAAK,KAAK,EAAG,KAAK,eAAgB,KAAK,YAAY,EAG5F,IAAMoB,EAAgB,KAAK,cAAc,KAAK,SAAS,EAEvD,KAAK,OACD,CAACA,EAAe,CAAC,EACjB,CACJ,EAEA,IAAMC,EAAe,KAAK,aAAa,EAEvC,KAAK,gBAAgB,EAErB,KAAK,cAAiBA,EAAgB,KAAK,aAAa,EAAI,EAC5D,KAAK,gBAAgB,EAErB,IAAMC,EAAgB,KAAK,eAAe,UAAU,OAAO,EACtD,KAAK,KAAK,KAAK,CAAC,EAEfC,EAAgB,KAAK,YAAY,EACjCC,EAAgBD,EAAgB,EACtCD,EACK,KACGN,GAASA,EAAM,OAAO,GAAG,EACpB,KAAK,QAAS,MAAM,EACpB,GAAG,qBAAsB,SAAUrB,EAAGmB,EAAG,CACtC,IAAMW,EAAM9B,EAAE,KAAO,OAAYmB,EAAInB,EAAE,GACnCK,EAAQ,WAAW,WAAW,CAAE,IAAAyB,EAAK,QAAS9B,EAAE,OAAQ,CAAC,EACzDK,EAAQ,WAAW,MAAM,EAEzBA,EAAQ,WAAW,MACf,CACI,IAAAyB,EACA,QAASlC,EAAA,IAAMI,EAAE,QAAR,UACb,EACA+B,CACJ,EAEJ1B,EAAQ,iBAAiB,EACzB0B,EAAQ,EAAE,gBAAgB,CAC9B,CAAC,EACA,GAAG,QAAS,SAA4B/B,EAAG,CACxC,IAAMgC,EAAWhC,EAAE,QAAQ,QAAQ,UAAU,EACzCA,EAAEK,EAAQ,QAAQ,EAAE,MAAM,IAC1BL,EAAE,SAAWA,EAAEK,EAAQ,QAAQ,EAAE,MAAM,GAE3CA,EAAQ,MAAML,EAAG,GAAIgC,CAAQ,CACjC,CAAC,EACA,GAAG,WAAY,SAA4BhC,EAAG,CAC3C,IAAMgC,EAAWhC,EAAE,QAAQ,QAAQ,UAAU,EACzCA,EAAEK,EAAQ,QAAQ,EAAE,MAAM,IAC1BL,EAAE,SAAWA,EAAEK,EAAQ,QAAQ,EAAE,MAAM,GAE3CA,EAAQ,MAAML,EAAG,GAAIgC,CAAQ,CACjC,CAAC,EACA,GAAG,UAAW,SAAUhC,EAAG,CACxBK,EAAQ,cAAcmB,EAAS,IAAI,EAAGxB,CAAC,EACvC,IAAMgC,EAAWhC,EAAE,QAAQ,QAAQ,UAAU,EAC7CK,EAAQ,QAAQL,EAAG,GAAIgC,CAAQ,CACnC,CAAC,EACA,GAAG,YAAa,SAAUhC,EAAG,CAC1B,IAAMiC,EAAQF,EAAQ,EACtB1B,EAAQ,SAAS,gBAAkBL,EAAE,QACrCK,EAAQ,SAAS,WAAa,CAC1B4B,EAAM,QACNA,EAAM,OACV,EACA5B,EAAQ,SACH,KAAKL,CAAC,EACN,QAAQ,EAAI,EACZ,WAAW,EAAI,EACf,OAAO,EAEZK,EAAQ,cAAcmB,EAAS,IAAI,EAAGxB,CAAC,EACvC,IAAMgC,EAAWhC,EAAE,QAAQ,QAAQ,UAAU,EAC7CK,EAAQ,UAAUL,EAAG,GAAIgC,CAAQ,CACrC,CAAC,EACA,GAAG,WAAY,SAAUhC,EAAG,CACzBK,EAAQ,SACH,QAAQ,EAAK,EACb,OAAO,EAEZA,EAAQ,cAAc,KAAM,IAAI,EAChC,IAAM2B,EAAWhC,EAAE,QAAQ,QAAQ,UAAU,EAC7CK,EAAQ,SAASL,EAAG,GAAIgC,CAAQ,CACpC,CAAC,EACA,KAAK,SAAUhC,EAAGmB,EAAG,CAClBnB,EAAE,KAAO,KACTA,EAAE,QAAUwB,EAAS,IAAI,EACzBxB,EAAE,EAAIK,EAAQ,cAAcL,EAAE,CAAC,CAAC,EAChC,IAAMkC,EAAO7B,EAAQ,cAAcL,EAAE,CAAC,CAAC,EACvC,GAAIK,EAAQ,YAAc,GAAI,CAC1B,IAAMS,EAAYd,EAAEK,EAAQ,WAAW,EACjC8B,EAAS9B,EAAQ,iBAAiBS,CAAS,EAAE,UAAUT,EAAQ,YAAYS,CAAS,EAAEK,CAAC,CAAC,EAC9FnB,EAAE,EAAIK,EAAQ,iBAAiBS,CAAS,EAAE,aAAaqB,CAAM,EAAI9B,EAAQ,iBAAiBS,CAAS,EAAE,YACzG,KAAO,CACH,IAAMsB,EAAK/B,EAAQ,cAAgB,GAAKc,EAAInB,EAAEK,EAAQ,WAAW,EACjEL,EAAE,EAAIK,EAAQ,SAAS,aAAaA,EAAQ,SAAS,UAAU+B,CAAE,CAAC,CACtE,CACApC,EAAE,MAAQ,CACN,GAAGA,EAAE,CAAC,EACN,KAAMA,EAAE,CAAC,CACb,EACAA,EAAE,MAAM,MAAQkC,EAAOlC,EAAE,EACzBA,EAAE,MAAM,OAAS0B,EACjB1B,EAAE,GAAK4B,EACP5B,EAAE,GAAK4B,EACP5B,EAAE,MAAM,OAAS6B,EACjB7B,EAAE,MAAM,QAAU6B,EAClB7B,EAAE,QAAQ,KAAK,YAAa,aAAaA,EAAE,EAAKA,EAAE,MAAM,MAAQ,CAAE,IAAIA,EAAE,EAAKA,EAAE,MAAM,OAAS,CAAE,GAAG,CACvG,CAAC,EACLsB,GAAUA,EACVC,GAAQA,EACH,KAAK,SAAUvB,EAAG,CACf,OAAOA,EAAE,OACb,CAAC,EACA,OAAO,CAChB,EACC,KAAK,UAAWA,GAAKA,EAAE,OAASA,EAAE,MAAM,OAAS,EAAI,CAAC,EACtD,KAAK,SAA6BA,EAAGmB,EAAG,CAErC,GADAnB,EAAE,KAAO,KACLK,EAAQ,YAAc,GAAI,CAC1B,IAAMS,EAAYd,EAAEK,EAAQ,WAAW,EACvCL,EAAE,EAAIK,EAAQ,mBAAmBL,EAAGmB,EAAG,GAAOd,EAAQ,cAAeS,CAAS,CAClF,MACId,EAAE,EAAIK,EAAQ,mBAAmBL,EAAGmB,EAAG,GAAOd,EAAQ,aAAa,CAE3E,CAAC,EACA,GAAG,gBAAiBL,GAAK,CACtB,IAAMQ,EAAK,KAAK,cAAcR,EAAE,CAAC,CAAC,EAE5BqC,EADK,KAAK,cAAcrC,EAAE,CAAC,CAAC,EACdQ,EACd8B,EAAShC,EAAI+B,EACnB,KAAK,OACD,CACI,CAAC7B,EAAK8B,EACN,CACJ,EACAA,CACJ,CACJ,CAAC,EAELlC,EAAQ,GAAG,gBAAiB,IAAI,CACpC,CACA,KAAKD,EAASC,EAAS,CACnB,KAAK,SAAS,OAAO,IAAI,EACzB,MAAM,KAAKD,EAASC,CAAO,CAC/B,CACA,mBAAmBJ,EAAG,EAAGuC,EAAgB,GAAOC,EAAe,CAAC,EAAG1B,EAAoB,CACnF,IAAMc,EAAgBY,EAAQ,YACxBX,EAAgBD,EAAgB,EAChCa,EAAUD,EAAQ,aACpBN,EACEQ,EAAI,MAAM,KAAK,WAAW,CAAC,EAAI,EAAI,KAAK,WAAW,EACnDC,EAAI,MAAM,KAAK,WAAW,CAAC,EAAI,EAAI,KAAK,WAAW,EACrDhC,EACEe,EAAe,KAAK,aAAa,EACvC1B,EAAE,KAAK,aAAa,cAAec,CAAS,EAExC,KAAK,WAAa,IAClBd,EAAE,KAAK,aAAa,aAAcA,EAAE,KAAK,UAAU,CAAC,EAGpDc,IAAc,QACdH,EAAI,KAAK,iBAAiBG,CAAS,EAAE,UAAU,KAAK,YAAYA,CAAS,EAAE,CAAC,CAAC,EAC7Ed,EAAE,KAAK,aAAa,SAAUW,CAAC,EAC/BX,EAAE,KAAK,aAAa,oBAAqB,KAAK,iBAAiBc,CAAS,EAAE,YAAY,EACtFd,EAAE,EAAI,KAAK,iBAAiBc,CAAS,EAAE,aAAaH,CAAC,EAAI,KAAK,iBAAiBG,CAAS,EAAE,aAC1Fd,EAAE,KAAK,aAAa,UAAWA,EAAE,CAAC,IAElCW,EAAI,KAAK,SAAS,UAAU,CAAC,EAC7BX,EAAE,EAAI,KAAK,SAAS,aAAaW,CAAC,GAElC,KAAK,WAAa,KAClB6B,EAAQ,KAAOxC,EAAE,KAAK,UAAU,GAE/BuC,GASDvC,EAAE,EAAI,KAAK,cAAcA,EAAE,CAAC,CAAC,EAAI2C,EACjCT,EAAO,KAAK,cAAclC,EAAE,CAAC,CAAC,EAAI2C,EAClC3C,EAAE,MAAQ,CACN,GAAGA,EAAE,CAAC,EACN,KAAMA,EAAE,CAAC,CACb,EACAA,EAAE,MAAM,OAASkC,EAAOlC,EAAE,GAAK2C,EAC/B3C,EAAE,GAAK0C,EACP1C,EAAE,MAAM,OAAS2C,IAhBjB3C,EAAE,EAAI,KAAK,cAAcA,EAAE,CAAC,CAAC,EAC7BkC,EAAO,KAAK,cAAclC,EAAE,CAAC,CAAC,EAC9BA,EAAE,MAAQ,CACN,GAAGA,EAAE,CAAC,EACN,KAAMA,EAAE,CAAC,CACb,EACAA,EAAE,MAAM,OAASkC,EAAOlC,EAAE,GAAK2C,GAYnC3C,EAAE,MAAM,OAAS0B,EACbZ,IAAc,QAAa,KAAK,SAAS,YAAc,IACvDd,EAAE,MAAM,OAAS,KAAK,SAAS,YAAc0B,GAE7C1B,EAAE,UAAY,QAAaA,EAAE,OAC7BA,EAAE,QAAUwB,EAASxB,EAAE,IAAI,GAE/BA,EAAE,QAAQ,KAAK,YAAa,aAAaA,EAAE,EAAKA,EAAE,MAAM,MAAQ,CAAE,IAAIA,EAAE,EAAKA,EAAE,MAAM,OAAS,CAAE,GAAG,EAEnGA,EAAE,GAAK4B,EACP5B,EAAE,GAAK4B,EACP5B,EAAE,MAAM,OAAS6B,EACjB7B,EAAE,MAAM,QAAU6B,EAClB7B,EAAE,MAAM,MAAQA,EAAE,MAAM,MAAQ,EAAI,EAAIA,EAAE,MAAM,MAChDA,EAAE,MAAM,OAASA,EAAE,MAAM,OAAS,EAAI,EAAIA,EAAE,MAAM,OAElD,IAAI4C,EAAO,KAAK,aAAa5C,EAAE,MAAM,KAAMA,EAAE,MAAM,MAAQyC,EAAS,KAAK,aAAa,EAElFG,IAAS5C,EAAE,MAAM,KACjB4C,EAAO,KAAK,aAAa5C,EAAE,MAAM,KAAMA,EAAE,MAAM,MAAQyC,CAAO,EAE9DzC,EAAE,MAAM,SAAW,KAAK,cAAgBwC,EAAQ,SAEhD1B,IAAc,QAAa,KAAK,SAAS,YAAc,IACvDd,EAAE,MAAM,SAAW,KAAK,IAAI,KAAK,cAAe,KAAK,SAAS,WAAW,EAAIwC,EAAQ,WAErF,CAAC,KAAK,OAAS,KAAK,MAAQxC,EAAE,EAAIA,EAAE,MAAM,UAC1C,KAAK,MAAQA,EAAE,EAAIA,EAAE,MAAM,SAE3B,CAAC,KAAK,OAAS,KAAK,MAAQA,EAAE,EAAIA,EAAE,MAAM,SAC1C,KAAK,MAAQA,EAAE,EAAIA,EAAE,MAAM,OAE/B6C,GACI,KAAK,eACL,CACI,GAAGL,EACH,GAAGxC,EAAE,MACL,KAAA4C,CACJ,EACA5C,EAAE,IACN,CACJ,CAEA,iBAAkB,CACd,KAAK,cAAgB,CACjB,aAAc,KAAK,aAAa,EAChC,WAAY,KAAK,WAAW,EAC5B,SAAU,KAAK,SAAS,EACxB,YAAa,KAAK,YAAY,EAC9B,KAAM,KAAK,KAAK,EAChB,OAAQ,KAAK,OAAO,EACpB,SAAU,KAAK,eAAe,EAC9B,aAAc,KAAK,aAAa,CACpC,CACJ,CAEO,WAAa,CAAE,EAAG,EAAG,EAAG,EAAG,EAAG,CAAE,EACvC,OAAO8C,EAAW,CAEd,OADA,KAAK,WAAaA,EACV,KAAK,WAAW,EAAG,CACvB,IAAK,YACD,KAAK,WAAaA,EAAU,EAC5B,KAAK,eAAiB,CAACA,EAAU,EAAG,CAAC,EACrC,KAAK,OAAO,KAAK,YAAa,aAAaA,EAAU,CAAC,YAAeA,EAAU,CAAC,KAAK,EACrF,MACJ,QACI,IAAMN,EAAU,KAAK,cACrB,KAAK,KAAK,EAAE,QAAQ,CAACxC,EAAGmB,IAAM,CAI1B,GAHI,KAAK,WAAa,KAClBqB,EAAQ,KAAOxC,EAAE,KAAK,UAAU,GAEhC,KAAK,YAAc,GAAI,CACvB,IAAMc,EAAYd,EAAE,KAAK,WAAW,EACpC,KAAK,mBAAmBA,EAAGmB,EAAG,GAAMqB,EAAS1B,CAAS,CAC1D,MACI,KAAK,mBAAmBd,EAAGmB,EAAG,GAAMqB,CAAO,CAEnD,CAAC,CACT,CAEA,KAAK,WAAWM,CAAS,CAC7B,CAEA,WAAWA,EAAW,CAEtB,CAEQ,YAAYC,EAAMC,EAA2BC,EAAyBC,EAA6B,CACvG,IAAMC,EAAY,CAAC,EACbC,EAAe,CAAC,EAChBC,EAAM,KAAK,iBAAiB,EAC5BC,EAAU,CAAC,CAAE,IAAK,IAAU,CAAC,EAC/BC,EAAY,EACZL,IAAc,QACdH,EAAK,QAAQ,CAAC/C,EAAGmB,IAAM,CACnBgC,EAAUhC,CAAC,EAAInB,EAAEkD,CAAS,EAC1BE,EAAapD,EAAEkD,CAAS,CAAC,EAAI,EACjC,CAAC,EACDK,EAAY,OAAO,KAAKH,CAAY,EAAE,QAEtCL,EAAK,QAAQ,CAAC/C,EAAGmB,IAAM,CACnB,QAASqC,EAAK,EAAGA,EAAKF,EAAQ,OAAQ,EAAEE,EACpC,GAAIrC,IAAM,GAAKmC,EAAQE,CAAE,EAAEP,CAAM,EAAII,GAAOrD,EAAEgD,CAAQ,EAAG,CACrDG,EAAUhC,CAAC,EAAIqC,EACXD,EAAYC,IAAID,EAAYC,GAChCF,EAAQE,CAAE,EAAEP,CAAM,EAAIjD,EAAEiD,CAAM,EAC9B,KACJ,CAEJ,GAAIE,EAAUhC,CAAC,IAAM,OAAW,CAC5BgC,EAAUhC,CAAC,EAAImC,EAAQ,OACvB,IAAM3C,EAAI,CAAC,EACXA,EAAEsC,CAAM,EAAIjD,EAAEiD,CAAM,EACpBK,EAAQ,KAAK3C,CAAQ,CACzB,CAEI4C,EAAYJ,EAAUhC,CAAC,IAAGoC,EAAYJ,EAAUhC,CAAC,EACzD,CAAC,EAEL,IAAMsC,GAAUF,EAAY,IAAM,KAAK,aAAa,EAAI,KAAK,OAAO,GACpE,MAAO,CACH,UAAAJ,EACA,UAAAI,EACA,YAAa,KAAK,OAAO,EAAIE,EAC7B,aAAchD,EAAc,EACvB,OAAO,CAAC,EAAG8C,EAAY,CAAC,CAAC,EACzB,MAAM,CAAC,EAAG,KAAK,IAAI,KAAK,OAAO,EAAGE,CAAM,CAAC,CAAC,CACnD,CACJ,CAIA,KAAKxD,EAAuC,CACxC,IAAMyD,EAAS,MAAM,KAAK,MAAM,KAAM,SAAS,EAC/C,OAAI,UAAU,OAAS,IACnB,KAAK,UAAY,KAAK,IAAI,GAAG,KAAK,KAAK,EAAE,IAAIxC,GAAKA,EAAE,CAAC,CAAC,CAAC,GAAK,EAC5D,KAAK,QAAU,KAAK,IAAI,GAAG,KAAK,KAAK,EAAE,IAAIA,GAAKA,EAAE,CAAC,CAAC,CAAC,GAAK,EAC1D,KAAK,gBAAgB,EAAI,GAEtBwC,CACX,CAEU,YACA,cACA,iBACA,gBACA,cACV,gBAAgBC,EAAe,GAAO,CAClC,IAAMC,EAAa,CAAC,EACdC,EAAkB,CAAC,EACnBC,EAAa,KAAK,WAAW,EAC7BC,EAAW,KAAK,SAAS,EACzBrC,EAAe,KAAK,aAAa,EAEnCA,IACA,KAAK,eAAiBA,EAAgB,KAAK,aAAa,EAAI,GAAMqC,IAGlEJ,GAAgB,KAAK,kBAAoBG,GAAc,KAAK,gBAAkBC,KAC9EF,EAAgB,GAAG,EAAIhE,EAAQ,SAAS,IAAKiE,EAAYC,CAAQ,EAAE,MACnE,KAAK,KAAK,EAAE,QAAQ/D,GAAK,CAChB4D,EAAW5D,EAAE,CAAC,CAAC,IAChB4D,EAAW5D,EAAE,CAAC,CAAC,EAAIH,EAAQ,SAASG,EAAE,CAAC,EAAG8D,EAAYC,CAAQ,EAAE,OAEpE/D,EAAE,CAAC,EAAE,MAAM,EAAE,EAAE,QAAQgE,GAAQ,CACtBH,EAAgBG,CAAI,IACrBH,EAAgBG,CAAI,EAAInE,EAAQ,SAASmE,EAAMF,EAAYC,CAAQ,EAAE,MAE7E,CAAC,CACL,CAAC,EACD,KAAK,YAAcH,EACnB,KAAK,iBAAmBC,GAE5B,KAAK,gBAAkBC,EACvB,KAAK,cAAgBC,CACzB,CAEA,aAAanB,EAAMqB,EAAOC,EAAQ,EAAG,CAEjC,GADiB,KAAK,YAAYtB,CAAI,EAAIsB,EAAQD,EAE9C,OAAOrB,EAEX,IAAIuB,EAAM,GACNC,EAAM,EACJC,EAASJ,EAAS,KAAK,iBAAiB,GAAG,EAAI,EACrD,QAAWD,KAAQpB,EAEf,GADAwB,GAAO,KAAK,iBAAiBJ,CAAI,EAC7BI,EAAMC,EACNF,GAAOH,MAEP,OAGR,OAAOK,EAAS,EAAI,GAAKF,EAAM,KACnC,CAEA,OAAOG,EAA2C,CAC9C,IAAIZ,EACJ,OAAI,KAAK,kBAAkB,GAAK,KAAK,mBAAmB,EACpDA,EAAS,MAAM,OAAO,KAAK,KAAM,CAC7B,MAAOY,EAAM,MACb,OAAQ,KAAK,KACjB,CAAC,EAEDZ,EAAS,MAAM,OAAO,MAAM,KAAM,SAAS,EAExCA,CACX,CAEA,kBAAmB,CAEnB,CAEA,cAAca,EAAUvE,EAAG,CAE3B,CAEA,MAAMwE,EAAKC,EAAMC,EAAK,CAEtB,CAEA,SAASF,EAAKC,EAAMC,EAAK,CAEzB,CAEA,QAAQF,EAAKC,EAAMC,EAAK,CACxB,CAEA,UAAUF,EAAKC,EAAMC,EAAK,CAC1B,CAEA,SAASF,EAAKC,EAAMC,EAAK,CACzB,CACJ,EACAhF,EAAW,UAAU,QAAU,uBAwD/BA,EAAW,UAAU,QAAQ,oBAAqB,GAAO,UAAW,4DAA4D,EAChIA,EAAW,UAAU,QAAQ,qBAAsB,GAAO,UAAW,6DAA6D,EAClIA,EAAW,UAAU,QAAQ,cAAe,KAAM,SAAU,8BAA8B,EAC1FA,EAAW,UAAU,QAAQ,kBAAmB,KAAM,SAAU,mCAAmC,EACnGA,EAAW,UAAU,QAAQ,gBAAiB,KAAM,SAAU,iCAAiC,EAC/FA,EAAW,UAAU,QAAQ,aAAc,KAAM,SAAU,6BAA6B,EACxFA,EAAW,UAAU,QAAQ,cAAe,KAAM,SAAU,8BAA8B,EAC1FA,EAAW,UAAU,QAAQ,eAAgB,KAAM,SAAU,0CAA0C,EACvGA,EAAW,UAAU,QAAQ,eAAgB,KAAM,SAAU,0CAA0C,EACvGA,EAAW,UAAU,QAAQ,aAAc,UAAW,MAAO,gDAAiD,CAAC,UAAW,WAAW,CAAC,EACtIA,EAAW,UAAU,QAAQ,eAAgB,EAAG,SAAU,8CAA8C,EACxGA,EAAW,UAAU,QAAQ,OAAQ,UAAW,SAAU,qCAAqC,EAC/FA,EAAW,UAAU,QAAQ,SAAU,KAAM,SAAU,iCAAiC,EACxFA,EAAW,UAAU,QAAQ,cAAe,KAAM,SAAU,0CAA0C,EACtGA,EAAW,UAAU,QAAQ,eAAgB,EAAG,SAAU,sCAAsC,EAChGA,EAAW,UAAU,QAAQ,aAAc,KAAM,SAAU,qCAAsC,KAAM,CAAE,SAAU,EAAK,CAAC,EACzHA,EAAW,UAAU,QAAQ,WAAY,GAAI,SAAU,8CAA8C,EACrGA,EAAW,UAAU,QAAQ,iBAAkB,UAAW,aAAc,gBAAgB,EACxFA,EAAW,UAAU,QAAQ,mBAAoB,EAAG,SAAU,kBAAkB,EAChFA,EAAW,UAAU,QAAQ,qBAAsB,GAAI,SAAU,sCAAsC,EACvGA,EAAW,UAAU,QAAQ,eAAgB,IAAK,SAAU,sCAAsC,EAClGA,EAAW,UAAU,QAAQ,SAAU,EAAG,SAAU,sCAAsC,EAC1FA,EAAW,UAAU,QAAQ,UAAW,GAAI,SAAU,cAAc,EACpEA,EAAW,UAAU,QAAQ,uBAAwB,UAAW,aAAc,sCAAsC,EACpHA,EAAW,UAAU,QAAQ,sBAAuB,UAAW,aAAc,qCAAqC,EC3rBlH,OAAS,QAAAiF,MAAY,iBACrB,OAAS,aAAAC,OAAiB,kBAKnB,IAAMC,EAAN,cAA6BC,EAAU,CAN9C,MAM8C,CAAAC,EAAA,uBAEhC,SAAiB,IAAIC,EAAK,QAAQ,EACvC,YAAY,KAAK,EACjB,KAAK,QAAQ,EACb,YAAY,MAAM,EAClB,YAAY,MAAM,EAClB,OAAO,CAAC,EACR,WAAW,GAAG,EAET,OAAqB,IAAIC,EAAW,QAAQ,EACjD,OAAO,SAAS,EAEX,YAAoB,IAAID,EAAK,QAAQ,EAC1C,YAAY,QAAQ,EACpB,KAAK,QAAQ,EACb,YAAY,MAAM,EAClB,YAAY,MAAM,EAClB,OAAO,CAAC,EACR,WAAW,GAAG,EAGT,gBACA,gBACA,mBACA,SACA,aACA,YAEA,cAEV,aAAc,CACV,MAAM,EACN,KAAK,cAAgB,SACrB,KAAK,cAAgB,UAAY,CAC7B,IAAME,EAAM,KAAK,OAAO,cAAc,MAAM,KAAK,OAAQ,SAAS,EAClE,OAAK,UAAU,OACR,KADuBA,CAElC,CACJ,CAIA,UAAUC,EAAyB,CAC/B,OAAK,UAAU,QACf,KAAK,OAAO,UAAUA,CAAC,EAChB,MAFuB,KAAK,OAAO,UAAU,CAGxD,CAEA,gBAAiB,CAEb,IAAMC,EAAI,KAAK,MAAM,EACfC,EAAI,KAAK,OAAO,EAEhBC,EAAa,KAAK,WAAW,EAE7BC,EAAiBF,EAAKC,EAAa,EACnCE,EAAgB,KAAK,YAAY,EACvC,KAAK,SACA,KAAK,SAAUF,CAAU,EACzB,KAAK,QAASF,CAAC,EACf,KAAK,OAAQ,aAAa,EAE/B,KAAK,gBAAgB,KAAK,YAAa,gBAAgB,EACvD,KAAK,SAAS,OAAO,CAAE,OAAQE,EAAY,MAAOF,CAAE,CAAC,EACrD,KAAK,aACA,KAAK,SAAUG,CAAa,EAC5B,KAAK,QAASH,CAAC,EACf,KAAK,OAAQ,aAAa,EAE/B,KAAK,gBAAgB,KAAK,YAAa,eAAeE,EAAaE,CAAa,GAAG,EACnF,KAAK,OAAO,OAAO,CAAE,OAAQD,EAAe,MAAOH,CAAE,CAAC,EACtD,KAAK,YACA,KAAK,SAAUE,CAAU,EACzB,KAAK,QAASF,CAAC,EACf,KAAK,OAAQ,aAAa,EAE/B,KAAK,mBAAmB,KAAK,YAAa,eAAeE,EAAaC,EAAgBC,CAAa,GAAG,EACtG,KAAK,YAAY,OAAO,CAAE,OAAQF,EAAY,MAAOF,CAAE,CAAC,CAC5D,CAEA,MAAMK,EAASC,EAAS,CACpB,MAAM,MAAMD,EAASC,CAAO,EAE5B,KAAK,OAAO,MAAQ,CAACC,EAAKC,EAAKC,IAAQ,CACnC,KAAK,MAAMF,EAAKC,EAAKC,CAAG,CAC5B,EAEA,KAAK,OAAO,SAAW,CAACF,EAAKC,EAAKC,IAAQ,CACtC,KAAK,SAASF,EAAKC,EAAKC,CAAG,CAC/B,EAEA,KAAK,gBAAkBH,EAAQ,OAAO,GAAG,EACpC,KAAK,QAAS,kBAAkB,EAErC,KAAK,SAAW,KAAK,gBAAgB,OAAO,MAAM,EAC7C,KAAK,QAAS,eAAe,EAElC,KAAK,gBAAkBA,EAAQ,OAAO,GAAG,EACpC,KAAK,QAAS,iBAAiB,EAEpC,KAAK,aAAe,KAAK,gBAAgB,OAAO,MAAM,EACjD,KAAK,QAAS,cAAc,EAEjC,KAAK,mBAAqBA,EAAQ,OAAO,GAAG,EACvC,KAAK,QAAS,qBAAqB,EAExC,KAAK,YAAc,KAAK,mBAAmB,OAAO,MAAM,EACnD,KAAK,QAAS,eAAe,EAElC,KAAK,SAAS,OAAO,KAAK,gBAAgB,KAAK,CAAC,EAChD,KAAK,OAAO,OAAO,KAAK,gBAAgB,KAAK,CAAC,EAAE,aAAa,EAAE,EAC/D,KAAK,YAAY,OAAO,KAAK,mBAAmB,KAAK,CAAC,EAEtD,KAAK,eAAe,EAEpB,KAAK,OAAO,WAAcI,GAAc,CACpC,KAAK,OAAOA,CAAS,CACzB,CACJ,CAEA,OAAOA,EAAW,CAEd,IAAMV,EAAI,KAAK,MAAM,EACfW,EAAM,KAAK,OAAO,UAElBC,EADO,KAAK,OAAO,QACJD,EACfE,EAAMD,EAAQZ,EACdc,EAAU,KAAK,MAAMH,EAAOE,GAAOH,EAAU,EAAIA,EAAU,EAAG,EAC9DK,EAAW,KAAK,KAAMH,EAAQF,EAAU,EAAKI,CAAO,EAE1D,KAAK,SACA,WAAW,KAAK,eAAe,CAAC,EAChC,SAAS,KAAK,aAAa,CAAC,EAC5B,WAAW,KAAK,eAAe,CAAC,EAChC,IAAIA,CAAO,EACX,KAAKC,CAAQ,EACb,OAAO,EAEZ,KAAK,YACA,WAAW,KAAK,eAAe,CAAC,EAChC,SAAS,KAAK,aAAa,CAAC,EAC5B,WAAW,KAAK,eAAe,CAAC,EAChC,IAAID,CAAO,EACX,KAAKC,CAAQ,EACb,OAAO,CAEhB,CAEA,OAAOV,EAASC,EAAS,CACrB,MAAM,OAAOD,EAASC,CAAO,EAC7B,KAAK,SAAS,WAAW,KAAK,WAAW,CAAC,EAAE,OAAO,EACnD,KAAK,YAAY,WAAW,KAAK,WAAW,CAAC,EAAE,OAAO,EACtD,KAAK,OAAO,OAAO,CACvB,CAEA,KAAKD,EAASC,EAAS,CACnB,KAAK,YAAY,OAAO,IAAI,EAC5B,KAAK,OAAO,OAAO,IAAI,EACvB,KAAK,SAAS,OAAO,IAAI,EACzB,MAAM,KAAKD,EAASC,CAAO,CAC/B,CAIA,QAAQP,EAA+B,CACnC,IAAMiB,EAAS,MAAM,QAAQ,MAAM,KAAM,SAAS,EAClD,OAAI,UAAU,OAAS,GACnB,KAAK,OAAO,QAAQjB,CAAC,EAElBiB,CACX,CAIA,KAAKjB,EAA+C,CAChD,IAAMiB,EAAS,MAAM,KAAK,MAAM,KAAM,SAAS,EAC/C,GAAI,UAAU,OAAS,EAAG,CACtB,IAAMC,EAAmB,KAAK,KAAK,EAAE,IAAI,GAAK,CAC1C,IAAMnB,EAAM,CAAC,GAAG,CAAC,EACjB,OAAAA,EAAI,CAAC,EAAI,MAAM,EAAE,CAAC,CAAQ,EAAI,IAAI,KAAK,EAAE,CAAC,CAAC,EAAE,QAAQ,EAAI,OAAO,EAAE,CAAC,CAAC,EACpEA,EAAI,CAAC,EAAI,MAAM,EAAE,CAAC,CAAQ,EAAI,IAAI,KAAK,EAAE,CAAC,CAAC,EAAE,QAAQ,EAAI,OAAO,EAAE,CAAC,CAAC,EAC7DA,CACX,CAAC,EACD,KAAK,OAAO,UAAY,KAAK,IAAI,GAAGmB,EAAU,IAAI,GAAK,EAAE,CAAC,CAAC,CAAC,GAAK,EACjE,KAAK,OAAO,QAAU,KAAK,IAAI,GAAGA,EAAU,IAAI,GAAK,EAAE,CAAC,CAAC,CAAC,GAAK,EAC/D,KAAK,OAAO,KAAKA,CAAS,CAC9B,CACA,OAAOD,CACX,CAEA,OAAOE,EAA2C,CAC9C,IAAMF,EAAS,MAAM,OAAO,MAAM,KAAM,SAAS,EAEjD,OAAI,KAAK,iBACL,KAAK,eAAe,EAGjBA,CACX,CAEA,MAAMT,EAAKC,EAAKC,EAAK,CAErB,CAEA,SAASF,EAAKC,EAAKC,EAAK,CAExB,CAEA,SAAU,CACN,OAAO,KAAK,OAAO,QACvB,CACJ,EACAhB,EAAe,UAAU,QAAU,2BA6CnCA,EAAe,UAAU,QAAQ,aAAc,KAAM,SAAU,0CAA2C,OAAW,CAAE,SAAU,EAAK,CAAC,EACvIA,EAAe,UAAU,QAAQ,aAAc,GAAI,SAAU,yBAAyB,EACtFA,EAAe,UAAU,QAAQ,mBAAoB,EAAG,SAAU,kBAAkB,EACpFA,EAAe,UAAU,QAAQ,qBAAsB,GAAI,SAAU,sCAAsC,EAC3GA,EAAe,UAAU,QAAQ,eAAgB,KAAM,SAAU,+BAA+B,EAChGA,EAAe,UAAU,QAAQ,iBAAkB,KAAM,SAAU,iCAAiC,EACpGA,EAAe,UAAU,QAAQ,iBAAkB,KAAM,SAAU,sBAAsB,EACzFA,EAAe,UAAU,aAAa,SAAU,QAAQ,EACxDA,EAAe,UAAU,aAAa,aAAc,QAAQ,EAC5DA,EAAe,UAAU,aAAa,cAAe,QAAQ,EAC7DA,EAAe,UAAU,aAAa,WAAY,QAAQ,EAC1DA,EAAe,UAAU,aAAa,aAAc,QAAQ,EAC5DA,EAAe,UAAU,aAAa,SAAU,QAAQ,EACxDA,EAAe,UAAU,aAAa,eAAgB,QAAQ,EAC9DA,EAAe,UAAU,aAAa,cAAe,QAAQ,EAC7DA,EAAe,UAAU,aAAa,kBAAmB,QAAQ,EACjEA,EAAe,UAAU,aAAa,gBAAiB,QAAQ,EAC/DA,EAAe,UAAU,aAAa,aAAc,QAAQ,EAC5DA,EAAe,UAAU,aAAa,cAAe,QAAQ,EAC7DA,EAAe,UAAU,aAAa,eAAgB,QAAQ,EAC9DA,EAAe,UAAU,aAAa,UAAW,QAAQ,EACzDA,EAAe,UAAU,aAAa,eAAgB,QAAQ,EC7R9D,OAAS,OAAO0B,GAAO,OAAOC,OAAa,kBAC3C,OAAS,QAAAC,MAAY,iBACrB,OAAS,WAAAC,OAAe,kBAKjB,IAAMC,EAAN,cAAmCC,EAAQ,CAPlD,MAOkD,CAAAC,EAAA,6BAEpC,SAAiB,IAAIC,EAAK,QAAQ,EACvC,YAAY,KAAK,EACjB,KAAK,QAAQ,EACb,YAAY,MAAM,EAClB,YAAY,MAAM,EAClB,OAAO,CAAC,EACR,WAAW,GAAG,EAET,OAAqB,IAAIC,EAAW,QAAQ,EACjD,OAAO,SAAS,EAChB,mBAAmB,EAAI,EAElB,YAAoB,IAAID,EAAK,QAAQ,EAC1C,YAAY,QAAQ,EACpB,KAAK,QAAQ,EACb,YAAY,MAAM,EAClB,YAAY,MAAM,EAClB,OAAO,CAAC,EACR,WAAW,GAAG,EAGT,gBACA,gBACA,mBACA,SACA,aACA,YAEV,aAAc,CACV,MAAM,EACN,KAAK,wBAAwB,QAAQ,EACrC,KAAK,wBAAwB,MAAM,CACvC,CAIA,UAAUE,EAAyB,CAC/B,OAAK,UAAU,QACf,KAAK,OAAO,UAAUA,CAAC,EAChB,MAFuB,KAAK,OAAO,UAAU,CAGxD,CAIA,cAAcA,EAA6D,CACvE,IAAMC,EAAM,KAAK,OAAO,cAAc,MAAM,KAAK,OAAQ,SAAS,EAClE,OAAK,UAAU,OACR,KADuBA,CAElC,CAEA,gBAAiB,CAEb,IAAMC,EAAI,KAAK,MAAM,EACfC,EAAI,KAAK,OAAO,EAEhBC,EAAa,KAAK,WAAW,EAC7BC,EAAiBF,EAAKC,EAAa,EAEzC,KAAK,aAAaA,CAAU,EAE5B,KAAK,OAAO,OAAO,CACf,MAAOF,EACP,OAAQE,CACZ,CAAC,EACD,KAAK,UAAU,OAAO,CAClB,MAAOF,EACP,OAAQG,CACZ,CAAC,EACD,KAAK,UAAU,OAAO,CAClB,MAAOH,EACP,OAAQE,CACZ,CAAC,EACD,KAAK,IAAI,EAAE,OAAO,EAClB,KAAK,OAAO,EAAE,OAAO,EACrB,KAAK,OAAO,EAAE,OAAO,CACzB,CAEA,MAAME,EAASC,EAAS,CACpB,MAAM,MAAMD,EAASC,CAAO,EAE5B,KAAK,OAAO,MAAQ,CAACC,EAAKC,EAAKC,IAAQ,CACnC,KAAK,MAAMF,EAAKC,EAAKC,CAAG,CAC5B,EAEA,KAAK,OAAO,SAAW,CAACF,EAAKC,EAAKC,IAAQ,CACtC,KAAK,SAASF,EAAKC,EAAKC,CAAG,CAC/B,EAEA,KAAK,IAAI,KAAK,QAAQ,EACtB,KAAK,OAAO,KAAK,MAAM,EACvB,KAAK,OAAO,KAAK,WAAW,EAE5B,KAAK,eAAe,EAEpB,KAAK,OAAO,WAAcC,GAAc,CACpC,KAAK,OAAOA,CAAS,CACzB,CACJ,CAEA,OAAOA,EAAW,CACd,IAAMT,EAAI,KAAK,MAAM,EACfU,EAAM,KAAK,OAAO,UAElBC,EADO,KAAK,OAAO,QACJD,EACfE,EAAMD,EAAQX,EACda,EAAU,KAAK,MAAMH,EAAOE,GAAOH,EAAU,EAAIA,EAAU,EAAG,EAC9DK,EAAW,KAAK,KAAMH,EAAQF,EAAU,EAAKI,CAAO,EAE1D,KAAK,SACA,WAAW,KAAK,eAAe,CAAC,EAChC,SAAS,KAAK,aAAa,CAAC,EAC5B,WAAW,KAAK,eAAe,CAAC,EAChC,IAAIA,CAAO,EACX,KAAKC,CAAQ,EACb,WAAW,EAEhB,KAAK,YACA,WAAW,KAAK,eAAe,CAAC,EAChC,SAAS,KAAK,aAAa,CAAC,EAC5B,WAAW,KAAK,eAAe,CAAC,EAChC,IAAID,CAAO,EACX,KAAKC,CAAQ,EACb,WAAW,CAEpB,CAEA,OAAOV,EAASC,EAAS,CACrB,MAAM,OAAOD,EAASC,CAAO,EAC7B,KAAK,SAAS,WAAW,KAAK,WAAW,CAAC,EAAE,OAAO,EACnD,KAAK,YAAY,WAAW,KAAK,WAAW,CAAC,EAAE,OAAO,EACtD,KAAK,OAAO,OAAO,CACvB,CAIA,QAAQP,EAA+B,CACnC,IAAMiB,EAAS,MAAM,QAAQ,MAAM,KAAM,SAAS,EAClD,OAAI,UAAU,OAAS,GACnB,KAAK,OAAO,QAAQjB,CAAC,EAElBiB,CACX,CAIA,KAAKjB,EAA+C,CAChD,IAAMiB,EAAS,MAAM,KAAK,MAAM,KAAM,SAAS,EAC/C,GAAI,UAAU,OAAS,EAAG,CACtB,IAAMC,EAAmB,KAAK,KAAK,EAAE,IAAI,GAAK,CAC1C,IAAMjB,EAAM,CAAC,GAAG,CAAC,EACjB,OAAAA,EAAI,CAAC,EAAI,MAAM,EAAE,CAAC,CAAQ,EAAI,IAAI,KAAK,EAAE,CAAC,CAAC,EAAE,QAAQ,EAAI,OAAO,EAAE,CAAC,CAAC,EACpEA,EAAI,CAAC,EAAI,MAAM,EAAE,CAAC,CAAQ,EAAI,IAAI,KAAK,EAAE,CAAC,CAAC,EAAE,QAAQ,EAAI,OAAO,EAAE,CAAC,CAAC,EAC7DA,CACX,CAAC,EAED,KAAK,OAAO,UAAYkB,GAAMD,EAAW,GAAK,EAAE,CAAC,CAAC,EAClD,KAAK,OAAO,QAAUE,GAAMF,EAAW,GAAK,EAAE,CAAC,CAAC,EAChD,KAAK,OAAO,KAAKA,CAAS,CAC9B,CACA,OAAOD,CACX,CAEA,OAAOI,EAA2C,CAC9C,IAAMJ,EAAS,MAAM,OAAO,MAAM,KAAM,SAAS,EAEjD,OAAI,KAAK,iBACL,KAAK,eAAe,EAGjBA,CACX,CAEA,MAAMT,EAAKC,EAAKC,EAAK,CAErB,CAEA,SAASF,EAAKC,EAAKC,EAAK,CAExB,CAEA,SAAU,CACN,OAAO,KAAK,OAAO,QACvB,CACJ,EACAf,EAAqB,UAAU,QAAU,iCA+CzCA,EAAqB,UAAU,QAAQ,aAAc,KAAM,SAAU,0CAA2C,OAAW,CAAE,SAAU,EAAK,CAAC,EAC7IA,EAAqB,UAAU,QAAQ,aAAc,GAAI,SAAU,yBAAyB,EAC5FA,EAAqB,UAAU,QAAQ,mBAAoB,EAAG,SAAU,kBAAkB,EAC1FA,EAAqB,UAAU,QAAQ,qBAAsB,GAAI,SAAU,sCAAsC,EACjHA,EAAqB,UAAU,QAAQ,eAAgB,KAAM,SAAU,+BAA+B,EACtGA,EAAqB,UAAU,QAAQ,iBAAkB,KAAM,SAAU,iCAAiC,EAC1GA,EAAqB,UAAU,QAAQ,iBAAkB,KAAM,SAAU,sBAAsB,EAC/FA,EAAqB,UAAU,aAAa,SAAU,QAAQ,EAC9DA,EAAqB,UAAU,aAAa,aAAc,QAAQ,EAClEA,EAAqB,UAAU,aAAa,cAAe,QAAQ,EACnEA,EAAqB,UAAU,aAAa,WAAY,QAAQ,EAChEA,EAAqB,UAAU,aAAa,aAAc,QAAQ,EAClEA,EAAqB,UAAU,aAAa,SAAU,QAAQ,EAC9DA,EAAqB,UAAU,aAAa,eAAgB,QAAQ,EACpEA,EAAqB,UAAU,aAAa,cAAe,QAAQ,EACnEA,EAAqB,UAAU,aAAa,kBAAmB,QAAQ,EACvEA,EAAqB,UAAU,aAAa,gBAAiB,QAAQ,EACrEA,EAAqB,UAAU,aAAa,aAAc,QAAQ,EAClEA,EAAqB,UAAU,aAAa,cAAe,QAAQ,EACnEA,EAAqB,UAAU,aAAa,eAAgB,QAAQ,EACpEA,EAAqB,UAAU,aAAa,eAAgB,QAAQ,EACpEA,EAAqB,UAAU,aAAa,UAAW,QAAQ,EAC/DA,EAAqB,UAAU,aAAa,uBAAwB,QAAQ,EAC5EA,EAAqB,UAAU,aAAa,sBAAuB,QAAQ,EAC3EA,EAAqB,UAAU,aAAa,eAAgB,QAAQ,ECxQpE,OAAS,cAAc2B,EAAc,aAAaC,MAAmB,kBAG9D,IAAMC,EAAN,cAA4BC,CAAe,CAHlD,MAGkD,CAAAC,EAAA,sBAEpC,oBAEV,aAAc,CACV,MAAM,EACN,KAAK,cAAgB,SACrB,KAAK,SAAS,KAAK,MAAM,EACzB,KAAK,YAAY,KAAK,MAAM,EAE5B,KAAK,YAAaC,GAAW,CACzB,IAAMC,EAASC,EAAY,IAAI,EACzBC,EAAYF,EAAOD,EAAE,CAAC,CAAC,EACvBI,EAAUH,EAAOD,EAAE,CAAC,CAAC,EAErBK,EAAYC,EAAa,KAAK,kBAAkB,CAAC,EACvD,MAAO,mCAAmCN,EAAE,CAAC,CAAC,aAAaK,EAAUF,CAAS,CAAC,UAAUE,EAAUD,CAAO,CAAC,QAC/G,CAAC,CACL,CAEA,OAAOG,EAASC,EAAS,CAGrB,GAFA,MAAM,OAAOD,EAASC,CAAO,EAEzB,KAAK,mBAAmB,EAAG,CAE3B,IAAIC,EAAe,IACfC,EAAe,KACfC,EAAa,GACbC,EAAc,GAClB,KAAK,KAAK,EAAE,IAAIC,GAAK,CACjB,IAAMC,EAAQ,IAAI,KAAKD,EAAE,CAAC,CAAC,EAAE,QAAQ,EAC/BE,EAAM,IAAI,KAAKF,EAAE,CAAC,CAAC,EAAE,QAAQ,EAC/BJ,EAAeK,IACfL,EAAeK,EACfH,EAAa,GAAKE,EAAE,CAAC,GAErBH,EAAeK,IACfL,EAAeK,EACfH,EAAc,GAAKC,EAAE,CAAC,EAE9B,CAAC,EACD,KAAK,SACA,KAAK,MAAM,EACX,YAAY,KAAK,YAAY,CAAC,EAC9B,YAAY,MAAM,EAClB,WAAW,KAAK,mBAAmB,EACnC,IAAIF,CAAU,EACd,KAAKC,CAAW,EAErB,KAAK,YACA,KAAK,MAAM,EACX,YAAY,KAAK,YAAY,CAAC,EAC9B,YAAY,MAAM,EAClB,WAAW,KAAK,mBAAmB,EACnC,IAAID,CAAU,EACd,KAAKC,CAAW,EAErB,KAAK,OAAO,UAAYH,EACxB,KAAK,OAAO,QAAUC,CAC1B,CACJ,CAEA,YAAYM,EAAU,CAClB,YAAK,aAAeA,EACpB,KAAK,QAAQ,EAAE,YAAY,KAAK,YAAY,EACrC,IACX,CAEA,eAAeC,EAAG,CAEd,IAAMC,EADYhB,EAAY,IAAI,EACLe,CAAC,EAG9B,OADmBX,EAAa,KAAK,YAAY,CAAC,EAChCY,CAAU,CAChC,CAEA,OAAOC,EAAW,CAEd,IAAMC,EAAI,KAAK,MAAM,EACfC,EAAM,KAAK,OAAO,UAElBC,EADO,KAAK,OAAO,QACJD,EACfE,EAAMD,EAAQF,EACdI,EAAU,KAAK,MAAMH,EAAOE,GAAOJ,EAAU,EAAIA,EAAU,EAAG,EAC9DM,EAAW,KAAK,KAAMH,EAAQH,EAAU,EAAKK,CAAO,EAE1D,KAAK,SACA,IAAI,KAAK,eAAeA,CAAO,CAAC,EAChC,KAAK,KAAK,eAAeC,CAAQ,CAAC,EAClC,OAAO,EAEZ,KAAK,YACA,IAAI,KAAK,eAAeD,CAAO,CAAC,EAChC,KAAK,KAAK,eAAeC,CAAQ,CAAC,EAClC,OAAO,CAEhB,CACJ,EACA5B,EAAc,UAAU,QAAU,0BAWlCA,EAAc,UAAU,QAAQ,cAAe,WAAY,SAAU,kEAAmE,KAAM,CAAE,SAAU,EAAK,CAAC,EAChKA,EAAc,UAAU,QAAQ,oBAAqB,WAAY,SAAU,8CAA8C,ECjHzH,OAAS,cAAc6B,EAAc,aAAaC,OAAmB,kBAGrE,IAAMC,EAAYC,GAAY,IAAI,EACrBC,EAAN,cAAkCC,CAAqB,CAJ9D,MAI8D,CAAAC,EAAA,4BAEhD,oBAEV,aAAc,CACV,MAAM,EACN,KAAK,SAAS,KAAK,MAAM,EACzB,KAAK,YAAY,KAAK,MAAM,EAE5B,KAAK,YAAaC,GAAW,CACzB,IAAMC,EAAYN,EAAUK,EAAE,CAAC,CAAC,EAC1BE,EAAUP,EAAUK,EAAE,CAAC,CAAC,EAExBG,EAAYC,EAAa,KAAK,kBAAkB,CAAC,EACvD,MAAO,mCAAmCJ,EAAE,CAAC,CAAC,aAAaG,EAAUF,CAAS,CAAC,UAAUE,EAAUD,CAAO,CAAC,QAC/G,CAAC,CACL,CAEA,OAAOG,EAASC,EAAS,CAGrB,GAFA,MAAM,OAAOD,EAASC,CAAO,EAEzB,KAAK,mBAAmB,EAAG,CAE3B,IAAIC,EAAe,IACfC,EAAe,KACfC,EAAa,GACbC,EAAc,GAClB,KAAK,KAAK,EAAE,QAAQC,GAAK,CACrB,IAAMC,EAAQ,IAAI,KAAKD,EAAE,CAAC,CAAC,EAAE,QAAQ,EAC/BE,EAAM,IAAI,KAAKF,EAAE,CAAC,CAAC,EAAE,QAAQ,EAC/BJ,EAAeK,IACfL,EAAeK,EACfH,EAAa,GAAKE,EAAE,CAAC,GAErBH,EAAeK,IACfL,EAAeK,EACfH,EAAc,GAAKC,EAAE,CAAC,EAE9B,CAAC,EACD,KAAK,SACA,KAAK,MAAM,EACX,YAAY,KAAK,YAAY,CAAC,EAC9B,YAAY,MAAM,EAClB,WAAW,KAAK,mBAAmB,EACnC,IAAIF,CAAU,EACd,KAAKC,CAAW,EAErB,KAAK,YACA,KAAK,MAAM,EACX,YAAY,KAAK,YAAY,CAAC,EAC9B,YAAY,MAAM,EAClB,WAAW,KAAK,mBAAmB,EACnC,IAAID,CAAU,EACd,KAAKC,CAAW,EAErB,KAAK,OAAO,UAAYH,EACxB,KAAK,OAAO,QAAUC,CAC1B,CACJ,CAEA,YAAYM,EAAU,CAClB,YAAK,aAAeA,EACpB,KAAK,QAAQ,EAAE,YAAY,KAAK,YAAY,EACrC,IACX,CAEA,eAAeC,EAAG,CACd,IAAMC,EAAarB,EAAUoB,CAAC,EAG9B,OADmBX,EAAa,KAAK,YAAY,CAAC,EAChCY,CAAU,CAChC,CAEA,OAAOC,EAAW,CAEd,IAAMC,EAAI,KAAK,MAAM,EACfC,EAAM,KAAK,OAAO,UAElBC,EADO,KAAK,OAAO,QACJD,EACfE,EAAMD,EAAQF,EACdI,EAAU,KAAK,MAAMH,EAAOE,GAAOJ,EAAU,EAAIA,EAAU,EAAG,EAC9DM,EAAW,KAAK,KAAMH,EAAQH,EAAU,EAAKK,CAAO,EAE1D,KAAK,SACA,IAAI,KAAK,eAAeA,CAAO,CAAC,EAChC,KAAK,KAAK,eAAeC,CAAQ,CAAC,EAClC,OAAO,EAEZ,KAAK,YACA,IAAI,KAAK,eAAeD,CAAO,CAAC,EAChC,KAAK,KAAK,eAAeC,CAAQ,CAAC,EAClC,OAAO,CAEhB,CAEA,YACJ,EACA1B,EAAoB,UAAU,QAAU,gCASxCA,EAAoB,UAAU,QAAQ,cAAe,WAAY,SAAU,kEAAmE,KAAM,CAAE,SAAU,EAAK,CAAC,EACtKA,EAAoB,UAAU,QAAQ,oBAAqB,WAAY,SAAU,8CAA8C",
|
|
6
|
-
"names": ["PKG_NAME", "PKG_VERSION", "BUILD_VERSION", "ITooltip", "Axis", "d3Event", "EntityPin", "EntityRect", "d3Local", "d3Select", "SVGWidget", "Utility", "d3Extent", "d3ScaleBand", "d3TimeFormat", "d3TimeParse", "d3Zoom", "d3ZoomIdentity", "e", "MiniGantt", "SVGWidget", "__name", "d3Local", "ITooltip", "Utility", "d", "Axis", "d3ScaleBand", "data", "d3Extent", "extent", "parser", "d3TimeParse", "formatter", "d3TimeFormat", "date1", "date2", "time1", "timeDiff", "pos", "d3ZoomIdentity", "d3Event", "domNode", "element", "d3Zoom", "width", "height", "low", "hi", "l", "r", "retVal", "events", "ranges", "brAxisBBox", "upperContentHeight", "lowerAxisHeight", "lowerHeight", "minYOffset", "row", "y_offset", "upperContentYOffset", "lowerAxisYOffset", "halfMinYOffset", "tlAxisBBox", "bucketData", "bucketIndex", "range", "i", "bucket", "vbLower", "vbHigher", "_d", "event_height", "context", "entityPins", "eventFontColor_idx", "eventBorderColor_idx", "eventBackgroundColor_idx", "title_counts", "type", "title_types", "title_group_offset", "entityPinsEnter", "d3Select", "entityPin", "EntityPin", "_title", "x_offset", "parsed_start_time", "formatted_start_time", "calc_height", "event_offset", "eventRangeHeight", "lines", "buckets", "entityRect", "EntityRect", "textBox", "x", "y", "rectWidth", "rectHeight", "fontHeightRatio", "paddingSize", "fontSize", "iconSize", "col", "sel", "textbox", "d3Event", "d3Select", "SVGZoomWidget", "Utility", "HTMLTooltip", "d3ScaleLinear", "render", "LabelledRect", "ReactGantt", "SVGZoomWidget", "__name", "Utility", "drawStartPosition", "HTMLTooltip", "d", "_", "LabelledRect", "domNode", "element", "context", "w", "x0", "x1", "d3ScaleLinear", "a", "b", "dataRow", "origIdx", "seriesKey", "gutter", "bucketOffset", "seriesKeys", "n", "i", "key", "enter", "update", "exit", "d3Select", "interpedStart", "bucketHeight", "itemSelection", "borderOffset1", "borderOffset2", "_id", "d3Event", "selected", "d3evt", "endX", "bucket", "_i", "xRange", "xScale", "transformEach", "options", "padding", "x", "k", "text", "render", "transform", "data", "startKey", "endKey", "bucketKey", "bucketMap", "bucketKeyMap", "tol", "buckets", "maxBucket", "i2", "height", "retVal", "forceMeasure", "textWidths", "characterWidths", "fontFamily", "fontSize", "char", "width", "scale", "ret", "sum", "_width", "_size", "_element", "row", "_col", "sel", "Axis", "SVGWidget", "ReactAxisGantt", "SVGWidget", "__name", "Axis", "ReactGantt", "ret", "_", "w", "h", "axisHeight", "contentHeight", "borderOffset1", "domNode", "element", "row", "col", "sel", "transform", "low", "range", "wpp", "nextLow", "nextHigh", "retVal", "ganttData", "_size", "d3Min", "d3Max", "Axis", "Border2", "ReactAxisGanttSeries", "Border2", "__name", "Axis", "ReactGantt", "_", "ret", "w", "h", "axisHeight", "contentHeight", "domNode", "element", "row", "col", "sel", "transform", "low", "range", "wpp", "nextLow", "nextHigh", "retVal", "ganttData", "d3Min", "d3Max", "_size", "d3TimeFormat", "d3TimeParse", "ReactTimeline", "ReactAxisGantt", "__name", "d", "parser", "d3TimeParse", "startTime", "endTime", "formatter", "d3TimeFormat", "domNode", "element", "minTimestamp", "maxTimestamp", "lowDateStr", "highDateStr", "n", "start", "end", "callback", "v", "parsedTime", "transform", "w", "low", "range", "wpp", "nextLow", "nextHigh", "d3TimeFormat", "d3TimeParse", "parseTime", "d3TimeParse", "ReactTimelineSeries", "ReactAxisGanttSeries", "__name", "d", "startTime", "endTime", "formatter", "d3TimeFormat", "domNode", "element", "minTimestamp", "maxTimestamp", "lowDateStr", "highDateStr", "n", "start", "end", "callback", "v", "parsedTime", "transform", "w", "low", "range", "wpp", "nextLow", "nextHigh"]
|
|
7
|
-
}
|
|
1
|
+
{"version":3,"file":"index.js","names":["bucketData: BucketInfo[]","ganttData: any[]","ganttData: any[]"],"sources":["../src/__package__.ts","../src/MiniGantt.ts","../src/ReactGantt.ts","../src/ReactAxisGantt.ts","../src/ReactAxisGanttSeries.ts","../src/ReactTimeline.ts","../src/ReactTimelineSeries.ts"],"sourcesContent":["export const PKG_NAME = \"@hpcc-js/timeline\";\nexport const PKG_VERSION = \"3.0.0\";\nexport const BUILD_VERSION = \"3.2.1\";\n","import { ITooltip } from \"@hpcc-js/api\";\nimport { Axis } from \"@hpcc-js/chart\";\nimport { d3Event, EntityPin, EntityRect, local as d3Local, select as d3Select, SVGWidget, Utility } from \"@hpcc-js/common\";\nimport { extent as d3Extent } from \"d3-array\";\nimport { scaleBand as d3ScaleBand } from \"d3-scale\";\nimport { timeFormat as d3TimeFormat, timeParse as d3TimeParse } from \"d3-time-format\";\nimport { zoom as d3Zoom, zoomIdentity as d3ZoomIdentity } from \"d3-zoom\";\n\nimport \"../src/MiniGantt.css\";\n\nexport class MiniGantt extends SVGWidget {\n protected tlAxis: Axis;\n protected brAxis: Axis;\n protected verticalBands;\n protected _zoom;\n protected gUpperContent;\n protected gUpperAxis;\n protected gMiddleContent;\n protected gLowerAxis;\n protected gLowerContent;\n private localRect = d3Local<EntityRect>();\n private localEntityPin = d3Local<EntityPin>();\n private tooltipFormatter: (date: Date) => string;\n private _dateCache;\n\n protected rootExtent;\n protected _title_idx = 0;\n protected _startDate_idx = 1;\n protected _endDate_idx = 2;\n protected _icon_idx = -1;\n protected _color_idx = -1;\n protected _yoffset_idx = -1;\n\n constructor() {\n super();\n ITooltip.call(this);\n Utility.SimpleSelectionMixin.call(this);\n\n this._drawStartPos = \"origin\";\n this.tooltipHTML((d: any) => `<center>${d[this._title_idx]}</center><br>${this.tooltipFormatter(this.brAxis.parse(d[this._startDate_idx]))} -> ${this.tooltipFormatter(this.brAxis.parse(d[this._endDate_idx]))}`);\n\n this.tlAxis = new Axis()\n .type(\"time\")\n ;\n this.brAxis = new Axis()\n .type(\"time\")\n ;\n this.verticalBands = d3ScaleBand()\n .paddingOuter(0.2)\n .paddingInner(0.2)\n ;\n }\n\n isHorizontal(): boolean {\n return this.orientation() === \"horizontal\";\n }\n\n fullExtent() {\n const data = [...this.data().map(d => d[this._startDate_idx]), ...this.data().filter(d => !!d[this._endDate_idx]).map(d => d[this._endDate_idx])];\n return d3Extent(data);\n }\n\n extent() {\n const extent = this.rootExtent ? [this.rootExtent[1], this.rootExtent[2]] : this.fullExtent();\n if (extent[0] !== undefined && extent[1] !== undefined) {\n if (extent[0] === extent[1] || this.centerOnMostRecent()) {\n const parser = d3TimeParse(this.timePattern());\n const formatter = d3TimeFormat(this.timePattern());\n const date1 = parser(extent[0]);\n const date2 = parser(extent[1]);\n if (extent[0] === extent[1]) {\n extent[0] = formatter(new Date(date1.setFullYear(date1.getFullYear() - 1)));\n extent[1] = formatter(new Date(date1.setFullYear(date1.getFullYear() + 2)));\n } else {\n const time1 = date1.getTime();\n const timeDiff = date2.getTime() - time1;\n extent[0] = formatter(date1);\n extent[1] = formatter(new Date(time1 + (timeDiff * 2)));\n }\n }\n }\n return extent;\n }\n\n dataStartPos(d) {\n if (typeof this._dateCache[d[this._startDate_idx]] !== \"undefined\") {\n return this._dateCache[d[this._startDate_idx]];\n }\n const pos = this.brAxis.scalePos(d[this._startDate_idx]);\n this._dateCache[d[this._startDate_idx]] = pos;\n return pos;\n }\n\n dataEndPos(d) {\n if (typeof this._dateCache[d[this._endDate_idx]] !== \"undefined\") {\n return this._dateCache[d[this._endDate_idx]];\n }\n const pos = this.brAxis.scalePos(d[this._endDate_idx]);\n this._dateCache[d[this._endDate_idx]] = pos;\n return pos;\n }\n\n dataWidth(d) {\n return this.dataEndPos(d) - this.dataStartPos(d);\n }\n\n private transform;\n resetZoom() {\n // Triggers a \"zoomed\" event ---\n this._zoom.transform(this.element(), d3ZoomIdentity.translate(0, this.isHorizontal() ? 0 : this.height()));\n }\n\n zoomed() {\n this.transform = d3Event().transform;\n this.render();\n }\n\n private background;\n enter(domNode, element) {\n super.enter(domNode, element);\n this._zoom = d3Zoom()\n .scaleExtent([0, this.maxZoom()])\n .on(\"zoom\", () => {\n this.zoomed();\n })\n ;\n\n this.background = element.append(\"rect\")\n .attr(\"fill\", \"white\")\n .attr(\"opacity\", 0)\n .on(\"dblclick\", () => {\n d3Event().stopPropagation();\n delete this.rootExtent;\n this.resetZoom();\n })\n ;\n this.gUpperContent = element.append(\"g\").attr(\"class\", \"gUpperContent\");\n this.gUpperAxis = element.append(\"g\").attr(\"class\", \"gUpperAxis\");\n this.gMiddleContent = element.append(\"g\").attr(\"class\", \"gMiddleContent\");\n this.gLowerAxis = element.append(\"g\").attr(\"class\", \"gLowerAxis\");\n this.gLowerContent = element.append(\"g\").attr(\"class\", \"gLowerContent\");\n this.tlAxis\n .target(this.gUpperAxis.node())\n .tickFormat(this.tickFormat())\n .guideTarget(this.gUpperAxis.append(\"g\").node())\n .shrinkToFit(\"none\")\n .overlapMode(this.tickFormat_exists() ? \"stagger\" : \"none\")\n .extend(0.1)\n ;\n this.brAxis\n .target(this.gLowerAxis.node())\n .tickFormat(this.tickFormat())\n .guideTarget(this.gLowerAxis.append(\"g\").node())\n .shrinkToFit(\"none\")\n .overlapMode(this.tickFormat_exists() ? \"stagger\" : \"none\")\n .extend(0.1)\n ;\n\n element.call(this._zoom);\n this._selection.widgetElement(this.gMiddleContent);\n }\n\n private _prevIsHorizontal;\n update(domNode, element) {\n super.update(domNode, element);\n\n this._dateCache = {};\n\n this._title_idx = this.titleColumn() !== null ? this.columns().indexOf(this.titleColumn()) : this._title_idx;\n this._startDate_idx = this.startDateColumn() !== null ? this.columns().indexOf(this.startDateColumn()) : this._startDate_idx;\n this._endDate_idx = this.endDateColumn() !== null ? this.columns().indexOf(this.endDateColumn()) : this._endDate_idx;\n this._icon_idx = this.iconColumn() !== null ? this.columns().indexOf(this.iconColumn()) : this._icon_idx;\n this._color_idx = this.colorColumn() !== null ? this.columns().indexOf(this.colorColumn()) : this._color_idx;\n this._yoffset_idx = this.yOffsetColumn() !== null ? this.columns().indexOf(this.yOffsetColumn()) : this._yoffset_idx;\n\n if (this._prevIsHorizontal !== this.isHorizontal()) {\n this._prevIsHorizontal = this.isHorizontal();\n this.resetZoom();\n return;\n }\n\n this.tooltipFormatter = d3TimeFormat(this.tooltipTimeFormat());\n\n const width = this.width();\n const height = this.height();\n\n this.background\n .attr(\"x\", 0)\n .attr(\"y\", 0)\n .attr(\"width\", width)\n .attr(\"height\", height)\n ;\n\n const extent = this.extent();\n this.tlAxis\n .x(width / 2)\n .orientation(this.isHorizontal() ? \"top\" : \"left\")\n .reverse(!this.isHorizontal())\n .timePattern(this.timePattern()) // \"%Y-%m-%dT%H:%M:%S.%LZ\"\n .width(width - 1)\n .low(extent[0])\n .high(extent[1])\n .updateScale()\n ;\n\n this.brAxis\n .x(width / 2)\n .y(height / 2)\n .orientation(this.isHorizontal() ? \"bottom\" : \"right\")\n .reverse(!this.isHorizontal())\n .timePattern(this.timePattern()) // \"%Y-%m-%dT%H:%M:%S.%LZ\"\n .width(width - 1)\n .height(height)\n .low(extent[0])\n .high(extent[1])\n .updateScale()\n ;\n\n if (this.transform) {\n let low;\n let hi;\n if (this.isHorizontal()) {\n low = this.tlAxis.parseInvert(this.tlAxis.invert(this.transform.invertX(0)));\n hi = this.tlAxis.parseInvert(this.tlAxis.invert(this.transform.invertX(width - 1)));\n } else {\n low = this.tlAxis.parseInvert(this.tlAxis.invert(- this.transform.invertY(0)));\n hi = this.tlAxis.parseInvert(this.tlAxis.invert(- this.transform.invertY(height - 1)));\n }\n this.tlAxis\n .low(low)\n .high(hi)\n .updateScale()\n ;\n this.brAxis\n .low(low)\n .high(hi)\n .updateScale()\n ;\n }\n\n const data = this.data().sort(this.isHorizontal() ? (l, r) => {\n const retVal = this.brAxis.scalePos(l[1]) - this.brAxis.scalePos(r[1]);\n if (retVal === 0) {\n return (\"\" + l[0]).localeCompare(\"\" + r[0]);\n }\n return retVal;\n } : (l, r) => {\n return this.brAxis.scalePos(r[1]) - this.brAxis.scalePos(l[1]);\n });\n const events = data.filter(d => !d[this._endDate_idx]);\n const ranges = data.filter(d => !!d[this._endDate_idx]);\n\n this.tlAxis\n .render()\n ;\n this.brAxis\n .render()\n ;\n const brAxisBBox = this.brAxis.getBBox();\n\n let upperContentHeight = this.updateEntityPins(events);\n const lowerAxisHeight = brAxisBBox.height;\n let lowerHeight = height - upperContentHeight;\n const minYOffset = this._yoffset_idx !== -1 ? Math.min.apply(undefined, this.data().filter(row => !isNaN(row[this._yoffset_idx])).map(row => row[this._yoffset_idx])) : 0;\n if (events.length > 0 && ranges.length === 0) {\n // ONLY EVENTS\n this.tlAxis.visible(false);\n let y_offset = upperContentHeight / 4;\n if (y_offset > (height / 2) - lowerAxisHeight) {\n y_offset = (height / 2) - lowerAxisHeight;\n }\n const upperContentYOffset = (height / 2) + y_offset;\n const lowerAxisYOffset = ((height / 2) - lowerAxisHeight - y_offset) * -1;\n const halfMinYOffset = minYOffset !== 0 ? minYOffset / 2 : 0;\n this.gUpperContent.attr(\"transform\", `translate(0, ${upperContentYOffset - halfMinYOffset})`);\n this.gLowerAxis.attr(\"transform\", `translate(0, ${lowerAxisYOffset - halfMinYOffset})`);\n } else if (events.length === 0 && ranges.length > 0) {\n // ONLY RANGES\n this.tlAxis.visible(true);\n this.gUpperContent.attr(\"transform\", `translate(0, ${upperContentHeight})`);\n this.gUpperAxis.attr(\"transform\", `translate(0, ${upperContentHeight})`);\n } else {\n upperContentHeight -= minYOffset;\n lowerHeight += minYOffset;\n // BOTH\n this.tlAxis.visible(true);\n this.gUpperContent.attr(\"transform\", `translate(0, ${upperContentHeight})`);\n this.gUpperAxis.attr(\"transform\", `translate(0, ${upperContentHeight})`);\n this.gMiddleContent.attr(\"transform\", `translate(0, ${upperContentHeight})`);\n }\n this.tlAxis\n .render()\n ;\n const tlAxisBBox = this.tlAxis.getBBox();\n interface BucketInfo {\n endPos: number;\n }\n const bucketData: BucketInfo[] = [];\n const bucketIndex = {};\n for (const range of ranges) {\n for (let i = 0; i < bucketData.length; ++i) {\n const bucket = bucketData[i];\n if (bucket.endPos + this.overlapTolerence() <= this.dataStartPos(range)) {\n bucketIndex[range] = i;\n bucket.endPos = this.dataEndPos(range);\n break;\n }\n }\n\n if (bucketIndex[range] === undefined) {\n bucketIndex[range] = bucketData.length;\n bucketData.push({\n endPos: this.dataEndPos(range)\n });\n }\n }\n\n const vbLower = this.isHorizontal() ? 0 + tlAxisBBox.height : 0 + tlAxisBBox.width;\n const vbHigher = this.isHorizontal() ? lowerHeight - brAxisBBox.height : width - brAxisBBox.width;\n this.verticalBands\n .range([vbLower, vbHigher])\n .domain(bucketData.map((_d, i) => i))\n ;\n\n if (ranges.length > 0) {\n this.updateEventRanges(events, ranges, bucketIndex, lowerHeight, tlAxisBBox, brAxisBBox, width);\n }\n }\n\n updateEntityPins(events) {\n let event_height = 0;\n const context = this;\n const entityPins = this.gUpperContent.selectAll(\".entity_pin\").data(events, d => d[0] + \":\" + d[1]);\n const eventFontColor_idx = this.eventFontColorColumn() ? this.columns().indexOf(this.eventFontColorColumn()) : -1;\n const eventBorderColor_idx = this.eventBorderColorColumn() ? this.columns().indexOf(this.eventBorderColorColumn()) : -1;\n const eventBackgroundColor_idx = this.eventBackgroundColorColumn() ? this.columns().indexOf(this.eventBackgroundColorColumn()) : -1;\n const title_counts = {};\n for (const d of events) {\n const type = typeof d[context._title_idx] !== \"undefined\" ? d[context._title_idx] : d[0];\n title_counts[type] = title_counts[type] ? title_counts[type] + 1 : 1;\n }\n const title_types = Object.keys(title_counts);\n const title_group_offset = context.eventGroupOffset();\n const entityPinsEnter = entityPins.enter().append(\"g\")\n .attr(\"class\", \"entity_pin\");\n entityPinsEnter.append(\"line\")\n .attr(\"class\", \"entity_line\");\n\n entityPinsEnter\n .on(\"mouseover\", function (d) {\n d3Select(this).raise();\n })\n .each(function (d, i) {\n const entityPin = new EntityPin()\n .target(this)\n .icon(\"\")\n .iconOnlyShowOnHover(context.hideIconWhenCollapsed())\n .titleOnlyShowOnHover(context.hideTitleWhenCollapsed())\n .descriptionOnlyShowOnHover(context.hideDescriptionWhenCollapsed())\n .annotationOnlyShowOnHover(context.hideAnnotationsWhenCollapsed())\n .iconDiameter(18)\n .iconPaddingPercent(1)\n .titleFontSize(14)\n .descriptionColor(\"#333\")\n .descriptionFontSize(15)\n .iconColor(eventFontColor_idx === -1 ? \"#333\" : d[eventFontColor_idx])\n .titleColor(eventFontColor_idx === -1 ? \"#333\" : d[eventFontColor_idx])\n .descriptionColor(eventFontColor_idx === -1 ? \"#333\" : d[eventFontColor_idx])\n .backgroundShape(\"pin\")\n .backgroundColorFill(eventFontColor_idx === -1 ? \"#f8f8f8\" : d[eventBackgroundColor_idx])\n .backgroundColorStroke(eventFontColor_idx === -1 ? \"#ccc\" : d[eventBorderColor_idx])\n .cornerRadius(5)\n .arrowHeight(10)\n .arrowWidth(16)\n ;\n context.localEntityPin.set(this, entityPin);\n })\n .merge(entityPins)\n .each(function (d, i) {\n const entityPin = context.localEntityPin.get(this);\n const _title = typeof d[context._title_idx] !== \"undefined\" ? d[context._title_idx] : entityPin.title();\n const x_offset = context.dataStartPos(d) - 0;\n let y_offset = ((title_types.indexOf(_title) % context.eventGroupMod()) * title_group_offset) - 5;\n if (typeof d[context._yoffset_idx] !== \"undefined\") y_offset += d[context._yoffset_idx] ? d[context._yoffset_idx] : 0;\n if (d[context._title_idx] !== entityPin.title() && d[context._startDate_idx] !== entityPin.description()) {\n const parsed_start_time = context.brAxis.parse(d[context._startDate_idx]);\n const formatted_start_time = context.tooltipFormatter(parsed_start_time);\n entityPin\n .x(x_offset)\n .y(y_offset)\n .iconOnlyShowOnHover(context.hideIconWhenCollapsed())\n .titleOnlyShowOnHover(context.hideTitleWhenCollapsed())\n .descriptionOnlyShowOnHover(context.hideDescriptionWhenCollapsed())\n .annotationOnlyShowOnHover(context.hideAnnotationsWhenCollapsed())\n .icon(typeof d[context._icon_idx] !== \"undefined\" ? d[context._icon_idx] : entityPin.icon())\n .title(_title)\n .description(formatted_start_time)\n .animationFrameRender()\n ;\n } else {\n entityPin.move({ x: x_offset, y: y_offset });\n }\n const calc_height = entityPin.calcHeight();\n if (event_height < calc_height) event_height = calc_height;\n\n d3Select(this).selectAll(\".entity_line\")\n .attr(\"x1\", x_offset)\n .attr(\"x2\", x_offset)\n .attr(\"y1\", 0)\n .attr(\"y2\", y_offset)\n .style(\"stroke\", eventFontColor_idx === -1 ? \"#ccc\" : d[eventBorderColor_idx])\n .style(\"stroke-width\", 1)\n ;\n })\n ;\n entityPins.exit()\n .each(function (d, i) {\n const entityPin = context.localEntityPin.get(this);\n entityPin.target(null);\n\n })\n .remove();\n const event_offset = Math.abs(Math.min(events.length, context.eventGroupMod()) * context.eventGroupOffset());\n return event_height + event_offset;\n }\n\n updateEventRanges(events, ranges, bucketIndex, eventRangeHeight, tlAxisBBox, brAxisBBox, width) {\n const context = this;\n\n const lines = this.gMiddleContent.selectAll(\".line\").data(events, d => {\n return d[context._title_idx];\n });\n lines.enter().append(\"line\")\n .attr(\"class\", \"line\")\n .merge(lines)\n .attr(this.isHorizontal() ? \"x1\" : \"y1\", d => this.dataStartPos(d) - 0)\n .attr(this.isHorizontal() ? \"x2\" : \"y2\", d => this.dataStartPos(d) - 0)\n .attr(this.isHorizontal() ? \"y1\" : \"x1\", this.isHorizontal() ? tlAxisBBox.height : tlAxisBBox.width)\n .attr(this.isHorizontal() ? \"y2\" : \"x2\", this.isHorizontal() ? eventRangeHeight - brAxisBBox.height : width - brAxisBBox.width)\n ;\n lines.exit().remove();\n const buckets = this.gMiddleContent.selectAll(\".buckets\").data(ranges, d => d[context._title_idx]);\n buckets.enter().append(\"g\")\n .attr(\"class\", \"buckets\")\n .call(this._selection.enter.bind(this._selection))\n .each(function (d) {\n const entityRect = new EntityRect()\n .target(this)\n .iconDiameter(28)\n .iconPaddingPercent(0)\n .titleFontSize(28)\n .titleColor(context.rangeFontColor())\n .descriptionColor(context.rangeFontColor())\n .iconColor(context.rangeFontColor())\n .backgroundShape(\"rect\")\n .backgroundColorFill(d[context._color_idx])\n ;\n context.localRect.set(this, entityRect);\n context.enterEntityRect(entityRect, d);\n })\n .on(\"click\", function (d) {\n context.click(context.rowToObj(d), \"range\", context._selection.selected(this));\n }, false)\n .on(\"dblclick\", function (d) {\n context.rootExtent = d;\n context.resetZoom();\n context.dblclick(context.rowToObj(d), \"range\", context._selection.selected(this));\n }, true)\n .on(\"mouseout.tooltip\", this.tooltip.hide)\n .on(\"mousemove.tooltip\", this.tooltip.show)\n .merge(buckets)\n .attr(\"transform\", d => context.isHorizontal() ?\n `translate(${this.dataStartPos(d)}, ${this.verticalBands(bucketIndex[d])}) ` :\n `translate(${this.verticalBands(bucketIndex[d])}, ${this.dataStartPos(d)}) `)\n .each(function (d) {\n const textBox = context.localRect.get(this);\n const x = context.dataWidth(d) / 2;\n const y = context.verticalBands.bandwidth() / 2;\n const rectWidth = Math.max(context.dataWidth(d), 2);\n const rectHeight = Math.max(context.verticalBands.bandwidth(), 2);\n const fontHeightRatio = 0.618;\n const paddingRatio = ((1 - fontHeightRatio) / 2);\n const paddingSize = paddingRatio * rectHeight;\n const fontSize = rectHeight * fontHeightRatio;\n const iconSize = fontSize;\n textBox\n .pos(context.isHorizontal() ? { x, y } : { x: y, y: x })\n .fixedHeight(context.isHorizontal() ? rectHeight : rectWidth)\n .fixedWidth(context.isHorizontal() ? rectWidth : rectHeight)\n .icon(typeof d[context._icon_idx] !== \"undefined\" ? d[context._icon_idx] : \"\")\n .title(typeof d[context._title_idx] !== \"undefined\" ? d[context._title_idx] : \"\")\n .padding(paddingSize)\n .iconDiameter(iconSize)\n .titleFontSize(fontSize)\n ;\n if (iconSize * 1.5 > rectWidth) {\n textBox.icon(null);\n }\n context.updateEntityRect(textBox, d[context._icon_idx]);\n textBox\n .render()\n ;\n });\n buckets.exit().remove();\n }\n\n exit(domNode, element) {\n this.brAxis.target(null);\n this.tlAxis.target(null);\n super.exit(domNode, element);\n }\n\n // Events ---\n click(row, col, sel) {\n }\n\n dblclick(row, col, sel) {\n }\n\n enterEntityRect(textbox: EntityRect, d) {\n }\n\n updateEntityRect(textbox: EntityRect, d) {\n }\n}\nMiniGantt.prototype._class += \" timeline_MiniGantt\";\nMiniGantt.prototype.implements(ITooltip.prototype);\nMiniGantt.prototype.mixin(Utility.SimpleSelectionMixin);\n\nexport interface MiniGantt {\n // ITooltip ---\n tooltip;\n tooltipHTML(_): string;\n tooltipFormat(_): string;\n\n // SimpleSelectionMixin\n _selection;\n\n // Properties ---\n timePattern(): string;\n timePattern(_: string): this;\n tickFormat(): string;\n tickFormat(_: string): this;\n tickFormat_exists(): boolean;\n tooltipTimeFormat(): string;\n tooltipTimeFormat(_: string): this;\n overlapTolerence(): number;\n overlapTolerence(_: number): this;\n orientation(): string;\n orientation(_: string): this;\n rangeFontColor(): string;\n rangeFontColor(_: string): this;\n titleColumn(): string;\n titleColumn(_: string): this;\n startDateColumn(): string;\n startDateColumn(_: string): this;\n endDateColumn(): string;\n endDateColumn(_: string): this;\n iconColumn(): string;\n iconColumn(_: string): this;\n colorColumn(): string;\n colorColumn(_: string): this;\n yOffsetColumn(): string;\n yOffsetColumn(_: string): this;\n maxZoom(): number;\n maxZoom(_: number): this;\n eventGroupMod(): number;\n eventGroupMod(_: number): this;\n eventGroupOffset(): number;\n eventGroupOffset(_: number): this;\n eventFontColorColumn(): string;\n eventFontColorColumn(_: string): this;\n eventBorderColorColumn(): string;\n eventBorderColorColumn(_: string): this;\n eventBackgroundColorColumn(): string;\n eventBackgroundColorColumn(_: string): this;\n hideIconWhenCollapsed(): boolean;\n hideIconWhenCollapsed(_: boolean): this;\n hideTitleWhenCollapsed(): boolean;\n hideTitleWhenCollapsed(_: boolean): this;\n hideDescriptionWhenCollapsed(): boolean;\n hideDescriptionWhenCollapsed(_: boolean): this;\n hideAnnotationsWhenCollapsed(): boolean;\n hideAnnotationsWhenCollapsed(_: boolean): this;\n centerOnMostRecent(): boolean;\n centerOnMostRecent(_: boolean): this;\n\n}\n\nMiniGantt.prototype.publish(\"timePattern\", \"%Y-%m-%d\", \"string\", \"timePattern\");\nMiniGantt.prototype.publish(\"tickFormat\", null, \"string\", \"tickFormat\", undefined, { optional: true });\nMiniGantt.prototype.publish(\"tooltipTimeFormat\", \"%Y-%m-%d\", \"string\", \"tooltipTimeFormat\");\nMiniGantt.prototype.publish(\"overlapTolerence\", 2, \"number\", \"overlapTolerence\");\nMiniGantt.prototype.publish(\"orientation\", \"horizontal\", \"set\", \"orientation\", [\"horizontal\", \"vertical\"]);\nMiniGantt.prototype.publish(\"rangeFontColor\", \"#ecf0f1\", \"html-color\", \"rangeFontColor\");\nMiniGantt.prototype.publish(\"titleColumn\", null, \"string\", \"titleColumn\");\nMiniGantt.prototype.publish(\"startDateColumn\", null, \"string\", \"startDateColumn\");\nMiniGantt.prototype.publish(\"endDateColumn\", null, \"string\", \"endDateColumn\");\nMiniGantt.prototype.publish(\"iconColumn\", null, \"string\", \"iconColumn\");\nMiniGantt.prototype.publish(\"colorColumn\", null, \"string\", \"colorColumn\");\nMiniGantt.prototype.publish(\"yOffsetColumn\", null, \"string\", \"yOffsetColumn\");\nMiniGantt.prototype.publish(\"maxZoom\", 16, \"number\", \"maxZoom\");\nMiniGantt.prototype.publish(\"eventGroupOffset\", -50, \"number\", \"eventGroupOffset\");\nMiniGantt.prototype.publish(\"eventGroupMod\", 5, \"number\", \"eventGroupMod\");\nMiniGantt.prototype.publish(\"eventFontColorColumn\", null, \"string\", \"eventFontColorColumn\");\nMiniGantt.prototype.publish(\"eventBorderColorColumn\", null, \"string\", \"eventBorderColorColumn\");\nMiniGantt.prototype.publish(\"eventBackgroundColorColumn\", null, \"string\", \"eventBackgroundColorColumn\");\nMiniGantt.prototype.publish(\"hideIconWhenCollapsed\", false, \"boolean\", \"hideIconWhenCollapsed\");\nMiniGantt.prototype.publish(\"hideTitleWhenCollapsed\", false, \"boolean\", \"hideTitleWhenCollapsed\");\nMiniGantt.prototype.publish(\"hideDescriptionWhenCollapsed\", false, \"boolean\", \"hideDescriptionWhenCollapsed\");\nMiniGantt.prototype.publish(\"hideAnnotationsWhenCollapsed\", true, \"boolean\", \"hideAnnotationsWhenCollapsed\");\nMiniGantt.prototype.publish(\"centerOnMostRecent\", false, \"boolean\", \"If true, the timeline will be centered on the most recent data point\");\n","import { d3Event, select as d3Select, SVGZoomWidget, Utility } from \"@hpcc-js/common\";\nimport { HTMLTooltip } from \"@hpcc-js/html\";\nimport { scaleLinear as d3ScaleLinear } from \"d3-scale\";\nimport { React, render, LabelledRect } from \"@hpcc-js/react\";\n\nexport type IGanttData = [string, number, number, any?];\n\nexport interface IRangeOptions {\n rangePadding: number;\n fontFamily: string;\n fontSize: number;\n strokeWidth?: number;\n fill: string;\n stroke: string;\n textFill: string;\n cornerRadius: number;\n}\n\nexport class ReactGantt extends SVGZoomWidget {\n\n protected _selection = new Utility.Selection(this);\n\n protected _buckets;\n protected _interpolateX;\n protected _interpolateY;\n\n protected _bucketsBySeries;\n protected _dataBySeries;\n protected _origIdxMap;\n private _seriesBackgrounds;\n\n protected _maxFontSize;\n\n public _tooltip;\n\n public _minStart: number;\n public _maxEnd: number;\n\n protected _title_idx = 0;\n protected _startDate_idx = 1;\n protected _endDate_idx = 2;\n protected _icon_idx = -1;\n protected _color_idx = -1;\n protected _series_idx = -1;\n protected _bucket_idx = -1;\n protected _yoffset_idx = -1;\n\n protected _maxX: number;\n protected _maxY: number;\n\n private _rangeOptions: IRangeOptions = {\n rangePadding: 2,\n fontFamily: \"Verdana\",\n fontSize: 12,\n fill: \"white\",\n stroke: \"black\",\n textFill: \"black\",\n cornerRadius: 3,\n strokeWidth: 0\n };\n\n constructor(drawStartPosition: \"origin\" | \"center\" = \"origin\") {\n super();\n this._drawStartPos = drawStartPosition;\n\n this.showToolbar_default(false);\n\n this._tooltip = new HTMLTooltip();\n this._tooltip\n .tooltipHTML(d => {\n return `<div style=\"text-align:center;\">${d[0]}<br/><br/>${d[1]} -> ${d[2]}</div>`;\n });\n this._tooltip\n .followCursor(true)\n ;\n }\n\n selection(_: any[]): this;\n selection(): any[];\n selection(_?: any[]): any[] | this {\n if (!arguments.length) return this._selection.get();\n this._selection.set(_);\n return this;\n }\n\n private _rangeRenderer: React.FunctionComponent = LabelledRect;\n rangeRenderer(): React.FunctionComponent;\n rangeRenderer(_: React.FunctionComponent): this;\n rangeRenderer(_?: React.FunctionComponent): this | React.FunctionComponent {\n if (!arguments.length) return this._rangeRenderer;\n this._rangeRenderer = _;\n return this._rangeRenderer;\n }\n\n enter(domNode, element) {\n super.enter(domNode, element);\n\n const context = this;\n element\n .on(\"click\", function (this: SVGElement, d) {\n context._selection.clear();\n });\n\n this._tooltip.target(domNode);\n }\n update(domNode, element) {\n super.update(domNode, element);\n\n this.zoomExtent([0.05, this.maxZoom()]);\n\n this._title_idx = this.titleColumn() !== null ? this.columns().indexOf(this.titleColumn()) : this._title_idx;\n this._startDate_idx = this.startDateColumn() !== null ? this.columns().indexOf(this.startDateColumn()) : this._startDate_idx;\n this._endDate_idx = this.endDateColumn() !== null ? this.columns().indexOf(this.endDateColumn()) : this._endDate_idx;\n this._icon_idx = this.iconColumn() !== null ? this.columns().indexOf(this.iconColumn()) : this._icon_idx;\n this._color_idx = this.colorColumn() !== null ? this.columns().indexOf(this.colorColumn()) : this._color_idx;\n this._series_idx = this.seriesColumn() !== null ? this.columns().indexOf(this.seriesColumn()) : this._series_idx;\n this._bucket_idx = this.bucketColumn() !== null ? this.columns().indexOf(this.bucketColumn()) : -1;\n\n const context = this;\n const w = this.width();\n\n const x0 = 0;\n const x1 = w;\n\n this._interpolateX = d3ScaleLinear()\n .domain([this._minStart, this._maxEnd])\n .range([x0, x1])\n ;\n\n this.data().sort((a, b) => a[1] - b[1]);\n\n if (this._series_idx > -1) {\n this._origIdxMap = {};\n this._dataBySeries = {};\n this._bucketsBySeries = {};\n this.data().forEach((dataRow, origIdx) => {\n const seriesKey = dataRow[this._series_idx];\n if (!this._dataBySeries[seriesKey]) {\n this._origIdxMap[seriesKey] = {};\n this._dataBySeries[seriesKey] = [];\n }\n this._dataBySeries[seriesKey].push({\n dataRow,\n origIdx\n });\n });\n const gutter = this.gutter();\n let bucketOffset = 0;\n const seriesKeys = Object.keys(this._dataBySeries);\n seriesKeys.forEach(seriesKey => {\n this._dataBySeries[seriesKey].sort((a, b) => a.dataRow[1] - b.dataRow[1]);\n this._bucketsBySeries[seriesKey] = this.calcBuckets(this._dataBySeries[seriesKey].map(n => n.dataRow), 1, 2);\n this._bucketsBySeries[seriesKey].bucketHeight = this.bucketHeight();\n this._bucketsBySeries[seriesKey].bucketOffset = bucketOffset;\n bucketOffset += (this._bucketsBySeries[seriesKey].bucketHeight + this.strokeWidth() + this.gutter()) * (this._bucketsBySeries[seriesKey].maxBucket + 1);\n this._dataBySeries[seriesKey].forEach((n, i) => {\n this._origIdxMap[seriesKey][n.origIdx] = i;\n });\n });\n this._seriesBackgrounds = this._renderElement.selectAll(\".series-background\")\n .data(seriesKeys.map(key => {\n return this._bucketsBySeries[key];\n }))\n ;\n this._seriesBackgrounds\n .join(\n enter => enter.append(\"rect\")\n .attr(\"class\", \"series-background\"),\n update => update,\n exit => exit\n .each(function (d) {\n delete d.element;\n })\n .remove()\n )\n .attr(\"opacity\", d => d.props && d.props.hidden ? 0 : 1)\n .each(function (this: SVGGElement, d, i) {\n d3Select(this)\n .attr(\"x\", 0)\n .attr(\"y\", d.bucketOffset - (gutter / 2))\n .attr(\"width\", w)\n .attr(\"height\", ((d.bucketHeight + gutter) * (d.maxBucket + 1)) + gutter)\n .attr(\"fill\", i % 2 ? context.oddSeriesBackground() : context.evenSeriesBackground())\n ;\n });\n } else {\n if (this._bucket_idx !== -1) {\n this._buckets = this.calcBuckets(this.data(), this._startDate_idx, this._endDate_idx, this._bucket_idx);\n } else {\n this._buckets = this.calcBuckets(this.data(), this._startDate_idx, this._endDate_idx);\n }\n }\n const interpedStart = this._interpolateX(this._minStart);\n\n this.zoomTo(\n [interpedStart, 0],\n 1\n );\n\n const bucketHeight = this.bucketHeight();\n\n this.setRangeOptions();\n\n this._maxFontScale = (bucketHeight - (this.rangePadding() * 2));\n this.measureDataText();\n\n const itemSelection = this._renderElement.selectAll(\".item\")\n .data(this.data())\n ;\n const borderOffset1 = this.strokeWidth();\n const borderOffset2 = borderOffset1 * 2;\n itemSelection\n .join(\n enter => enter.append(\"g\")\n .attr(\"class\", \"item\")\n .on(\"click.selectionBag\", function (d, i) {\n const _id = d.id === undefined ? i : d.id;\n if (context._selection.isSelected({ _id, element: d.element })) {\n context._selection.clear();\n } else {\n context._selection.click(\n {\n _id,\n element: () => d.element\n },\n d3Event\n );\n }\n context.selectionChanged();\n d3Event().stopPropagation();\n })\n .on(\"click\", function (this: SVGElement, d) {\n const selected = d.element.classed(\"selected\");\n if (d[context.columns().length]) {\n d.__lparam = d[context.columns().length];\n }\n context.click(d, \"\", selected);\n })\n .on(\"dblclick\", function (this: SVGElement, d) {\n const selected = d.element.classed(\"selected\");\n if (d[context.columns().length]) {\n d.__lparam = d[context.columns().length];\n }\n context.click(d, \"\", selected);\n })\n .on(\"mousein\", function (d) {\n context.highlightItem(d3Select(this), d);\n const selected = d.element.classed(\"selected\");\n context.mousein(d, \"\", selected);\n })\n .on(\"mouseover\", function (d) {\n const d3evt = d3Event();\n context._tooltip._triggerElement = d.element;\n context._tooltip._cursorLoc = [\n d3evt.clientX,\n d3evt.clientY\n ];\n context._tooltip\n .data(d)\n .visible(true)\n .fitContent(true)\n .render()\n ;\n context.highlightItem(d3Select(this), d);\n const selected = d.element.classed(\"selected\");\n context.mouseover(d, \"\", selected);\n })\n .on(\"mouseout\", function (d) {\n context._tooltip\n .visible(false)\n .render()\n ;\n context.highlightItem(null, null);\n const selected = d.element.classed(\"selected\");\n context.mouseout(d, \"\", selected);\n })\n .each(function (d, i) {\n d.that = this;\n d.element = d3Select(this);\n d.x = context._interpolateX(d[1]);\n const endX = context._interpolateX(d[2]);\n if (context._series_idx > -1) {\n const seriesKey = d[context._series_idx];\n const bucket = context._bucketsBySeries[seriesKey].bucketMap[context._origIdxMap[seriesKey][i]];\n d.y = context._bucketsBySeries[seriesKey].interpolateY(bucket) + context._bucketsBySeries[seriesKey].bucketOffset;\n } else {\n const _i = context._bucket_idx === -1 ? i : d[context._bucket_idx];\n d.y = context._buckets.interpolateY(context._buckets.bucketMap[_i]);\n }\n d.props = {\n ...d[3],\n text: d[0]\n };\n d.props.width = endX - d.x;\n d.props.height = bucketHeight;\n d.x += borderOffset1;\n d.y += borderOffset1;\n d.props.width -= borderOffset2;\n d.props.height -= borderOffset2;\n d.element.attr(\"transform\", `translate(${d.x + (d.props.width / 2)} ${d.y + (d.props.height / 2)})`);\n }),\n update => update,\n exit => exit\n .each(function (d) {\n delete d.element;\n })\n .remove()\n )\n .attr(\"opacity\", d => d.props && d.props.hidden ? 0 : 1)\n .each(function (this: SVGGElement, d, i) {\n d.that = this;\n if (context._series_idx > -1) {\n const seriesKey = d[context._series_idx];\n d.x = context.renderRangeElement(d, i, false, context._rangeOptions, seriesKey);\n } else {\n d.x = context.renderRangeElement(d, i, false, context._rangeOptions);\n }\n })\n .on(\"dblclick.zoom\", d => {\n const x1 = this._interpolateX(d[1]);\n const x2 = this._interpolateX(d[2]);\n const xRange = x2 - x1;\n const xScale = w / xRange;\n this.zoomTo(\n [\n -x1 * xScale,\n 0\n ],\n xScale\n );\n })\n ;\n element.on(\"dblclick.zoom\", null);\n }\n exit(domNode, element) {\n this._tooltip.target(null);\n super.exit(domNode, element);\n }\n renderRangeElement(d, i, transformEach = false, options: any = {}, seriesKey?: string) {\n const borderOffset1 = options.strokeWidth;\n const borderOffset2 = borderOffset1 * 2;\n const padding = options.rangePadding;\n let endX;\n const x = isNaN(this._transform.x) ? 0 : this._transform.x;\n const k = isNaN(this._transform.k) ? 1 : this._transform.k;\n let b;\n const bucketHeight = this.bucketHeight();\n d.that.setAttribute(\"data-series\", seriesKey);\n\n if (this._color_idx > -1) {\n d.that.setAttribute(\"data-color\", d[this._color_idx]);\n }\n\n if (seriesKey !== undefined) {\n b = this._bucketsBySeries[seriesKey].bucketMap[this._origIdxMap[seriesKey][i]];\n d.that.setAttribute(\"data-b\", b);\n d.that.setAttribute(\"data-bucketOffset\", this._bucketsBySeries[seriesKey].bucketOffset);\n d.y = this._bucketsBySeries[seriesKey].interpolateY(b) + this._bucketsBySeries[seriesKey].bucketOffset;\n d.that.setAttribute(\"data-dy\", d.y);\n } else {\n b = this._buckets.bucketMap[i];\n d.y = this._buckets.interpolateY(b);\n }\n if (this._color_idx > -1) {\n options.fill = d[this._color_idx];\n }\n if (!transformEach) {\n d.x = this._interpolateX(d[1]);\n endX = this._interpolateX(d[2]);\n d.props = {\n ...d[3],\n text: d[0]\n };\n d.props.width = (endX - d.x) / k;\n } else {\n d.x = this._interpolateX(d[1]) * k;\n endX = this._interpolateX(d[2]) * k;\n d.props = {\n ...d[3],\n text: d[0]\n };\n d.props.width = (endX - d.x) / k;\n d.x += x;\n d.props.width *= k;\n }\n d.props.height = bucketHeight;\n if (seriesKey === undefined && this._buckets.bucketScale < 1) {\n d.props.height = this._buckets.bucketScale * bucketHeight;\n }\n if (d.element === undefined && d.that) {\n d.element = d3Select(d.that);\n }\n d.element.attr(\"transform\", `translate(${d.x + (d.props.width / 2)} ${d.y + (d.props.height / 2)})`);\n\n d.x += borderOffset1;\n d.y += borderOffset1;\n d.props.width -= borderOffset2;\n d.props.height -= borderOffset2;\n d.props.width = d.props.width < 1 ? 1 : d.props.width;\n d.props.height = d.props.height < 1 ? 1 : d.props.height;\n\n let text = this.truncateText(d.props.text, d.props.width - padding, this._maxFontScale);\n\n if (text !== d.props.text) {\n text = this.truncateText(d.props.text, d.props.width - padding);\n } else {\n d.props.fontSize = this._maxFontScale * options.fontSize;\n }\n if (seriesKey === undefined && this._buckets.bucketScale < 1) {\n d.props.fontSize = Math.min(this._maxFontScale, this._buckets.bucketScale) * options.fontSize;\n }\n if (!this._maxY || this._maxY < d.y + d.props.height) {\n this._maxY = d.y + d.props.height;\n }\n if (!this._maxX || this._maxX < d.x + d.props.width) {\n this._maxX = d.x + d.props.width;\n }\n render(\n this._rangeRenderer,\n {\n ...options,\n ...d.props,\n text,\n },\n d.that\n );\n }\n\n setRangeOptions() {\n this._rangeOptions = {\n rangePadding: this.rangePadding(),\n fontFamily: this.fontFamily(),\n fontSize: this.fontSize(),\n strokeWidth: this.strokeWidth(),\n fill: this.fill(),\n stroke: this.stroke(),\n textFill: this.rangeFontColor(),\n cornerRadius: this.cornerRadius(),\n };\n }\n\n public _transform = { k: 1, x: 0, y: 0 };\n zoomed(transform) {\n this._transform = transform;\n switch (this.renderMode()) {\n case \"scale-all\":\n this._zoomScale = transform.k;\n this._zoomTranslate = [transform.x, 0];\n this._zoomG.attr(\"transform\", `translate(${transform.x} ${0})scale(${transform.k} 1)`);\n break;\n default:\n const options = this._rangeOptions;\n this.data().forEach((d, i) => {\n if (this._color_idx > -1) {\n options.fill = d[this._color_idx];\n }\n if (this._series_idx > -1) {\n const seriesKey = d[this._series_idx];\n this.renderRangeElement(d, i, true, options, seriesKey);\n } else {\n this.renderRangeElement(d, i, true, options);\n }\n });\n }\n\n this.zoomedHook(transform);\n }\n\n zoomedHook(transform) {\n\n }\n\n private calcBuckets(data, startKey: string | number, endKey: string | number, bucketKey?: string | number) {\n const bucketMap = {};\n const bucketKeyMap = {};\n const tol = this.overlapTolerence();\n const buckets = [{ end: -Infinity }];\n let maxBucket = 0;\n if (bucketKey !== undefined) {\n data.forEach((d, i) => {\n bucketMap[i] = d[bucketKey];\n bucketKeyMap[d[bucketKey]] = true;\n });\n maxBucket = Object.keys(bucketKeyMap).length;\n } else {\n data.forEach((d, i) => {\n for (let i2 = 0; i2 < buckets.length; ++i2) {\n if (i === 0 || buckets[i2][endKey] + tol <= d[startKey]) {\n bucketMap[i] = i2;\n if (maxBucket < i2) maxBucket = i2;\n buckets[i2][endKey] = d[endKey];\n break;\n }\n }\n if (bucketMap[i] === undefined) {\n bucketMap[i] = buckets.length;\n const b = {};\n b[endKey] = d[endKey];\n buckets.push(b as any);\n }\n\n if (maxBucket < bucketMap[i]) maxBucket = bucketMap[i];\n });\n }\n const height = (maxBucket + 1) * (this.bucketHeight() + this.gutter());\n return {\n bucketMap,\n maxBucket,\n bucketScale: this.height() / height,\n interpolateY: d3ScaleLinear()\n .domain([0, maxBucket + 1])\n .range([0, Math.min(this.height(), height)])\n };\n }\n\n data(): IGanttData[];\n data(_: IGanttData[]): this;\n data(_?: IGanttData[]): this | IGanttData[] {\n const retVal = super.data.apply(this, arguments);\n if (arguments.length > 0) {\n this._minStart = Math.min(...this.data().map(n => n[1])) ?? 0;\n this._maxEnd = Math.max(...this.data().map(n => n[2])) ?? 1;\n this.measureDataText(true);\n }\n return retVal;\n }\n\n protected _textWidths;\n protected _maxFontScale;\n protected _characterWidths;\n protected _prevFontFamily;\n protected _prevFontSize;\n measureDataText(forceMeasure = false) {\n const textWidths = {};\n const characterWidths = {};\n const fontFamily = this.fontFamily();\n const fontSize = this.fontSize();\n const bucketHeight = this.bucketHeight();\n\n if (bucketHeight) {\n this._maxFontScale = (bucketHeight - (this.rangePadding() * 2)) / fontSize;\n }\n\n if (forceMeasure || this._prevFontFamily !== fontFamily || this._prevFontSize !== fontSize) {\n characterWidths[\".\"] = Utility.textSize(\".\", fontFamily, fontSize).width;\n this.data().forEach(d => {\n if (!textWidths[d[0]]) {\n textWidths[d[0]] = Utility.textSize(d[0], fontFamily, fontSize).width;\n }\n d[0].split(\"\").forEach(char => {\n if (!characterWidths[char]) {\n characterWidths[char] = Utility.textSize(char, fontFamily, fontSize).width;\n }\n });\n });\n this._textWidths = textWidths;\n this._characterWidths = characterWidths;\n }\n this._prevFontFamily = fontFamily;\n this._prevFontSize = fontSize;\n }\n\n truncateText(text, width, scale = 1) {\n const textFits = this._textWidths[text] * scale < width;\n if (textFits) {\n return text;\n }\n let ret = \"\";\n let sum = 0;\n const _width = width - (this._characterWidths[\".\"] * 3);\n for (const char of text) {\n sum += this._characterWidths[char];\n if (sum < _width) {\n ret += char;\n } else {\n break;\n }\n }\n return _width < 0 ? \"\" : ret + \"...\";\n }\n\n resize(_size?: { width: number, height: number }) {\n let retVal;\n if (this.fitWidthToContent() || this.fitHeightToContent()) {\n retVal = super.resize.call(this, {\n width: _size.width,\n height: this._maxY\n });\n } else {\n retVal = super.resize.apply(this, arguments);\n }\n return retVal;\n }\n\n selectionChanged() {\n\n }\n\n highlightItem(_element, d) {\n\n }\n\n click(row, _col, sel) {\n\n }\n\n dblclick(row, _col, sel) {\n\n }\n\n mousein(row, _col, sel) {\n }\n\n mouseover(row, _col, sel) {\n }\n\n mouseout(row, _col, sel) {\n }\n}\nReactGantt.prototype._class += \" timeline_ReactGantt\";\n\nexport interface ReactGantt {\n titleColumn(): string;\n titleColumn(_: string): this;\n startDateColumn(): string;\n startDateColumn(_: string): this;\n endDateColumn(): string;\n endDateColumn(_: string): this;\n iconColumn(): string;\n iconColumn(_: string): this;\n colorColumn(): string;\n colorColumn(_: string): this;\n seriesColumn(): string;\n seriesColumn(_: string): this;\n bucketColumn(): string;\n bucketColumn(_: string): this;\n overlapTolerence(): number;\n overlapTolerence(_: number): this;\n smallestRangeWidth(): number;\n smallestRangeWidth(_: number): this;\n bucketHeight(): number;\n bucketHeight(_: number): this;\n gutter(): number;\n gutter(_: number): this;\n showToolbar_default(_: boolean): this;\n fontSize(): number;\n fontSize(_: number): this;\n fontFamily(): string;\n fontFamily(_: string): this;\n strokeWidth(): number;\n strokeWidth(_: number): this;\n stroke(): string;\n stroke(_: string): this;\n cornerRadius(): number;\n cornerRadius(_: number): this;\n fill(): string;\n fill(_: string): this;\n rangeFontColor(): string;\n rangeFontColor(_: string): this;\n rangePadding(): number;\n rangePadding(_: number): this;\n renderMode(): \"default\" | \"scale-all\";\n renderMode(_: \"default\" | \"scale-all\"): this;\n maxZoom(): number;\n maxZoom(_: number): this;\n fitWidthToContent(): boolean;\n fitWidthToContent(_: boolean): this;\n fitHeightToContent(): boolean;\n fitHeightToContent(_: boolean): this;\n evenSeriesBackground(): string;\n evenSeriesBackground(_: string): this;\n oddSeriesBackground(): string;\n oddSeriesBackground(_: string): this;\n}\n\nReactGantt.prototype.publish(\"fitWidthToContent\", false, \"boolean\", \"If true, resize will simply reapply the bounding box width\");\nReactGantt.prototype.publish(\"fitHeightToContent\", false, \"boolean\", \"If true, resize will simply reapply the bounding box height\");\nReactGantt.prototype.publish(\"titleColumn\", null, \"string\", \"Column name to for the title\");\nReactGantt.prototype.publish(\"startDateColumn\", null, \"string\", \"Column name to for the start date\");\nReactGantt.prototype.publish(\"endDateColumn\", null, \"string\", \"Column name to for the end date\");\nReactGantt.prototype.publish(\"iconColumn\", null, \"string\", \"Column name to for the icon\");\nReactGantt.prototype.publish(\"colorColumn\", null, \"string\", \"Column name to for the color\");\nReactGantt.prototype.publish(\"seriesColumn\", null, \"string\", \"Column name to for the series identifier\");\nReactGantt.prototype.publish(\"bucketColumn\", null, \"string\", \"Column name to for the bucket identifier\");\nReactGantt.prototype.publish(\"renderMode\", \"default\", \"set\", \"Render modes vary in features and performance\", [\"default\", \"scale-all\"]);\nReactGantt.prototype.publish(\"rangePadding\", 3, \"number\", \"Padding within each range rectangle (pixels)\");\nReactGantt.prototype.publish(\"fill\", \"#1f77b4\", \"string\", \"Background color of range rectangle\");\nReactGantt.prototype.publish(\"stroke\", null, \"string\", \"Color of range rectangle border\");\nReactGantt.prototype.publish(\"strokeWidth\", null, \"number\", \"Width of range rectangle border (pixels)\");\nReactGantt.prototype.publish(\"cornerRadius\", 3, \"number\", \"Space between range buckets (pixels)\");\nReactGantt.prototype.publish(\"fontFamily\", null, \"string\", \"Font family within range rectangle\", null, { optional: true });\nReactGantt.prototype.publish(\"fontSize\", 10, \"number\", \"Size of font within range rectangle (pixels)\");\nReactGantt.prototype.publish(\"rangeFontColor\", \"#ecf0f1\", \"html-color\", \"rangeFontColor\");\nReactGantt.prototype.publish(\"overlapTolerence\", 2, \"number\", \"overlapTolerence\");\nReactGantt.prototype.publish(\"smallestRangeWidth\", 10, \"number\", \"Width of the shortest range (pixels)\");\nReactGantt.prototype.publish(\"bucketHeight\", 100, \"number\", \"Max height of range element (pixels)\");\nReactGantt.prototype.publish(\"gutter\", 2, \"number\", \"Space between range buckets (pixels)\");\nReactGantt.prototype.publish(\"maxZoom\", 16, \"number\", \"Maximum zoom\");\nReactGantt.prototype.publish(\"evenSeriesBackground\", \"#FFFFFF\", \"html-color\", \"Background color of even series rows\");\nReactGantt.prototype.publish(\"oddSeriesBackground\", \"#DDDDDD\", \"html-color\", \"Background color of odd series rows\");\n","import { Axis } from \"@hpcc-js/chart\";\nimport { SVGWidget } from \"@hpcc-js/common\";\nimport { ReactGantt } from \"./ReactGantt.ts\";\n\nexport type IAxisGanttData = [string, number | string, number | string, any?] | any[];\n\nexport class ReactAxisGantt extends SVGWidget {\n\n protected _topAxis: Axis = new Axis(\"center\")\n .orientation(\"top\")\n .type(\"linear\")\n .shrinkToFit(\"none\")\n .overlapMode(\"hide\")\n .extend(0)\n .tickFormat(\"d\")\n ;\n protected _gantt: ReactGantt = new ReactGantt(\"center\")\n .stroke(\"#000000\")\n ;\n protected _bottomAxis: Axis = new Axis(\"center\")\n .orientation(\"bottom\")\n .type(\"linear\")\n .shrinkToFit(\"none\")\n .overlapMode(\"hide\")\n .extend(0)\n .tickFormat(\"d\")\n ;\n\n protected _topAxisElement;\n protected _contentElement;\n protected _bottomAxisElement;\n protected _topRect;\n protected _contentRect;\n protected _bottomRect;\n\n protected rangeRenderer;\n\n constructor() {\n super();\n this._drawStartPos = \"origin\";\n this.rangeRenderer = function () {\n const ret = this._gantt.rangeRenderer.apply(this._gantt, arguments);\n if (!arguments.length) return ret;\n return this;\n };\n }\n\n selection(_: any[]): this;\n selection(): any[];\n selection(_?: any[]): any[] | this {\n if (!arguments.length) return this._gantt.selection();\n this._gantt.selection(_);\n return this;\n }\n\n resizeWrappers() {\n\n const w = this.width();\n const h = this.height();\n\n const axisHeight = this.axisHeight(); //TODO: Dynamic scaling to allow for small resolutions?\n\n const contentHeight = (h - (axisHeight * 2));\n const borderOffset1 = this.strokeWidth();\n this._topRect\n .attr(\"height\", axisHeight)\n .attr(\"width\", w)\n .attr(\"fill\", \"transparent\")\n ;\n this._topAxisElement.attr(\"transform\", \"translate(0 0)\");\n this._topAxis.resize({ height: axisHeight, width: w });\n this._contentRect\n .attr(\"height\", contentHeight)\n .attr(\"width\", w)\n .attr(\"fill\", \"transparent\")\n ;\n this._contentElement.attr(\"transform\", `translate(0 ${axisHeight + borderOffset1})`);\n this._gantt.resize({ height: contentHeight, width: w });\n this._bottomRect\n .attr(\"height\", axisHeight)\n .attr(\"width\", w)\n .attr(\"fill\", \"transparent\")\n ;\n this._bottomAxisElement.attr(\"transform\", `translate(0 ${axisHeight + contentHeight + borderOffset1})`);\n this._bottomAxis.resize({ height: axisHeight, width: w });\n }\n\n enter(domNode, element) {\n super.enter(domNode, element);\n\n this._gantt.click = (row, col, sel) => {\n this.click(row, col, sel);\n };\n\n this._gantt.dblclick = (row, col, sel) => {\n this.dblclick(row, col, sel);\n };\n\n this._topAxisElement = element.append(\"g\")\n .attr(\"class\", \"top-axis-wrapper\")\n ;\n this._topRect = this._topAxisElement.append(\"rect\")\n .attr(\"class\", \"top-axis-rect\")\n ;\n this._contentElement = element.append(\"g\")\n .attr(\"class\", \"content-wrapper\")\n ;\n this._contentRect = this._contentElement.append(\"rect\")\n .attr(\"class\", \"content-rect\")\n ;\n this._bottomAxisElement = element.append(\"g\")\n .attr(\"class\", \"bottom-axis-wrapper\")\n ;\n this._bottomRect = this._bottomAxisElement.append(\"rect\")\n .attr(\"class\", \"top-axis-rect\")\n ;\n this._topAxis.target(this._topAxisElement.node());\n this._gantt.target(this._contentElement.node()).bucketHeight(30);\n this._bottomAxis.target(this._bottomAxisElement.node());\n\n this.resizeWrappers();\n\n this._gantt.zoomedHook = (transform) => {\n this.onzoom(transform);\n };\n }\n\n onzoom(transform) {\n\n const w = this.width();\n const low = this._gantt._minStart;\n const high = this._gantt._maxEnd;\n const range = high - low;\n const wpp = range / w;\n const nextLow = Math.floor(low - (wpp * (transform.x / transform.k)));\n const nextHigh = Math.ceil((range / transform.k) + nextLow);\n\n this._topAxis\n .fontFamily(this.axisFontFamily())\n .fontSize(this.axisFontSize())\n .tickLength(this.axisTickLength())\n .low(nextLow)\n .high(nextHigh)\n .render()\n ;\n this._bottomAxis\n .fontFamily(this.axisFontFamily())\n .fontSize(this.axisFontSize())\n .tickLength(this.axisTickLength())\n .low(nextLow)\n .high(nextHigh)\n .render()\n ;\n }\n\n update(domNode, element) {\n super.update(domNode, element);\n this._topAxis.tickFormat(this.tickFormat()).render();\n this._bottomAxis.tickFormat(this.tickFormat()).render();\n this._gantt.render();\n }\n\n exit(domNode, element) {\n this._bottomAxis.target(null);\n this._gantt.target(null);\n this._topAxis.target(null);\n super.exit(domNode, element);\n }\n\n columns(): string[];\n columns(_: string[]): this;\n columns(_?: string[]): this | string[] {\n const retVal = super.columns.apply(this, arguments);\n if (arguments.length > 0) {\n this._gantt.columns(_);\n }\n return retVal;\n }\n\n data(): IAxisGanttData[];\n data(_: IAxisGanttData[]): this;\n data(_?: IAxisGanttData[]): this | IAxisGanttData[] {\n const retVal = super.data.apply(this, arguments);\n if (arguments.length > 0) {\n const ganttData: any[] = this.data().map(n => {\n const ret = [...n];\n ret[1] = isNaN(n[1] as any) ? new Date(n[1]).getTime() : Number(n[1]);\n ret[2] = isNaN(n[2] as any) ? new Date(n[2]).getTime() : Number(n[2]);\n return ret;\n });\n this._gantt._minStart = Math.min(...ganttData.map(n => n[1])) ?? 0;\n this._gantt._maxEnd = Math.max(...ganttData.map(n => n[2])) ?? 1;\n this._gantt.data(ganttData);\n }\n return retVal;\n }\n\n resize(_size?: { width: number, height: number }) {\n const retVal = super.resize.apply(this, arguments);\n\n if (this._topAxisElement) {\n this.resizeWrappers();\n }\n\n return retVal;\n }\n\n click(row, col, sel) {\n\n }\n\n dblclick(row, col, sel) {\n\n }\n\n tooltip() {\n return this._gantt._tooltip;\n }\n}\nReactAxisGantt.prototype._class += \" timeline_ReactAxisGantt\";\n\nexport interface ReactAxisGantt {\n tickFormat(): string;\n tickFormat(_: string): this;\n tickFormat_exists(): boolean;\n overlapTolerence(): number;\n overlapTolerence(_: number): this;\n smallestRangeWidth(): number;\n smallestRangeWidth(_: number): this;\n scaleMode(): boolean;\n scaleMode(_: boolean): this;\n fontSize(): number;\n fontSize(_: number): this;\n fontFamily(): string;\n fontFamily(_: string): this;\n strokeWidth(): number;\n strokeWidth(_: number): this;\n stroke(): string;\n stroke(_: string): this;\n cornerRadius(): number;\n cornerRadius(_: number): this;\n axisFontSize(): number;\n axisFontSize(_: number): this;\n axisFontFamily(): string;\n axisFontFamily(_: string): this;\n axisTickLength(): number;\n axisTickLength(_: number): this;\n axisHeight(): number;\n axisHeight(_: number): this;\n titleColumn(): string;\n titleColumn(_: string): this;\n startDateColumn(): string;\n startDateColumn(_: string): this;\n endDateColumn(): string;\n endDateColumn(_: string): this;\n iconColumn(): string;\n iconColumn(_: string): this;\n colorColumn(): string;\n colorColumn(_: string): this;\n bucketColumn(): string;\n bucketColumn(_: string): this;\n maxZoom(): number;\n maxZoom(_: number): this;\n}\nReactAxisGantt.prototype.publish(\"tickFormat\", null, \"string\", \"Format rule applied to axis tick labels\", undefined, { optional: true });\nReactAxisGantt.prototype.publish(\"axisHeight\", 22, \"number\", \"Height of axes (pixels)\");\nReactAxisGantt.prototype.publish(\"overlapTolerence\", 2, \"number\", \"overlapTolerence\");\nReactAxisGantt.prototype.publish(\"smallestRangeWidth\", 10, \"number\", \"Width of the shortest range (pixels)\");\nReactAxisGantt.prototype.publish(\"axisFontSize\", null, \"number\", \"Font size of axis tick labels\");\nReactAxisGantt.prototype.publish(\"axisFontFamily\", null, \"string\", \"Font family of axis tick labels\");\nReactAxisGantt.prototype.publish(\"axisTickLength\", null, \"number\", \"Length of axis ticks\");\nReactAxisGantt.prototype.publishProxy(\"gutter\", \"_gantt\");\nReactAxisGantt.prototype.publishProxy(\"renderMode\", \"_gantt\");\nReactAxisGantt.prototype.publishProxy(\"strokeWidth\", \"_gantt\");\nReactAxisGantt.prototype.publishProxy(\"fontSize\", \"_gantt\");\nReactAxisGantt.prototype.publishProxy(\"fontFamily\", \"_gantt\");\nReactAxisGantt.prototype.publishProxy(\"stroke\", \"_gantt\");\nReactAxisGantt.prototype.publishProxy(\"cornerRadius\", \"_gantt\");\nReactAxisGantt.prototype.publishProxy(\"titleColumn\", \"_gantt\");\nReactAxisGantt.prototype.publishProxy(\"startDateColumn\", \"_gantt\");\nReactAxisGantt.prototype.publishProxy(\"endDateColumn\", \"_gantt\");\nReactAxisGantt.prototype.publishProxy(\"iconColumn\", \"_gantt\");\nReactAxisGantt.prototype.publishProxy(\"colorColumn\", \"_gantt\");\nReactAxisGantt.prototype.publishProxy(\"bucketColumn\", \"_gantt\");\nReactAxisGantt.prototype.publishProxy(\"maxZoom\", \"_gantt\");\nReactAxisGantt.prototype.publishProxy(\"bucketHeight\", \"_gantt\");\n","import { min as d3Min, max as d3Max } from \"d3-array\";\nimport { Axis } from \"@hpcc-js/chart\";\nimport { Border2 } from \"@hpcc-js/layout\";\nimport { React } from \"@hpcc-js/react\";\nimport { ReactGantt } from \"./ReactGantt.ts\";\nimport { IAxisGanttData } from \"./ReactAxisGantt.ts\";\n\nexport class ReactAxisGanttSeries extends Border2 {\n\n protected _topAxis: Axis = new Axis(\"origin\")\n .orientation(\"top\")\n .type(\"linear\")\n .shrinkToFit(\"none\")\n .overlapMode(\"hide\")\n .extend(0)\n .tickFormat(\"d\")\n ;\n protected _gantt: ReactGantt = new ReactGantt(\"origin\")\n .stroke(\"#000000\")\n .fitHeightToContent(true)\n ;\n protected _bottomAxis: Axis = new Axis(\"origin\")\n .orientation(\"bottom\")\n .type(\"linear\")\n .shrinkToFit(\"none\")\n .overlapMode(\"hide\")\n .extend(0)\n .tickFormat(\"d\")\n ;\n\n protected _topAxisElement;\n protected _contentElement;\n protected _bottomAxisElement;\n protected _topRect;\n protected _contentRect;\n protected _bottomRect;\n\n constructor() {\n super();\n this.centerOverflowX_default(\"hidden\");\n this.centerOverflowY_default(\"auto\");\n }\n\n selection(_: any[]): this;\n selection(): any[];\n selection(_?: any[]): any[] | this {\n if (!arguments.length) return this._gantt.selection();\n this._gantt.selection(_);\n return this;\n }\n\n rangeRenderer(): React.FunctionComponent;\n rangeRenderer(_: React.FunctionComponent): this;\n rangeRenderer(_?: React.FunctionComponent): this | React.FunctionComponent {\n const ret = this._gantt.rangeRenderer.apply(this._gantt, arguments);\n if (!arguments.length) return ret;\n return this;\n }\n\n resizeWrappers() {\n\n const w = this.width();\n const h = this.height();\n\n const axisHeight = this.axisHeight(); //TODO: Dynamic scaling to allow for small resolutions?\n const contentHeight = (h - (axisHeight * 2));\n\n this.bottomHeight(axisHeight);\n\n this._topWA.resize({\n width: w,\n height: axisHeight\n });\n this._centerWA.resize({\n width: w,\n height: contentHeight\n });\n this._bottomWA.resize({\n width: w,\n height: axisHeight\n });\n this.top().render();\n this.bottom().render();\n this.center().render();\n }\n\n enter(domNode, element) {\n super.enter(domNode, element);\n\n this._gantt.click = (row, col, sel) => {\n this.click(row, col, sel);\n };\n\n this._gantt.dblclick = (row, col, sel) => {\n this.dblclick(row, col, sel);\n };\n\n this.top(this._topAxis);\n this.center(this._gantt);\n this.bottom(this._bottomAxis);\n\n this.resizeWrappers();\n\n this._gantt.zoomedHook = (transform) => {\n this.onzoom(transform);\n };\n }\n\n onzoom(transform) {\n const w = this.width();\n const low = this._gantt._minStart;\n const high = this._gantt._maxEnd;\n const range = high - low;\n const wpp = range / w;\n const nextLow = Math.floor(low - (wpp * (transform.x / transform.k)));\n const nextHigh = Math.ceil((range / transform.k) + nextLow);\n\n this._topAxis\n .fontFamily(this.axisFontFamily())\n .fontSize(this.axisFontSize())\n .tickLength(this.axisTickLength())\n .low(nextLow)\n .high(nextHigh)\n .lazyRender()\n ;\n this._bottomAxis\n .fontFamily(this.axisFontFamily())\n .fontSize(this.axisFontSize())\n .tickLength(this.axisTickLength())\n .low(nextLow)\n .high(nextHigh)\n .lazyRender()\n ;\n }\n\n update(domNode, element) {\n super.update(domNode, element);\n this._topAxis.tickFormat(this.tickFormat()).render();\n this._bottomAxis.tickFormat(this.tickFormat()).render();\n this._gantt.render();\n }\n\n columns(): string[];\n columns(_: string[]): this;\n columns(_?: string[]): this | string[] {\n const retVal = super.columns.apply(this, arguments);\n if (arguments.length > 0) {\n this._gantt.columns(_);\n }\n return retVal;\n }\n\n data(): IAxisGanttData[];\n data(_: IAxisGanttData[]): this;\n data(_?: IAxisGanttData[]): this | IAxisGanttData[] {\n const retVal = super.data.apply(this, arguments);\n if (arguments.length > 0) {\n const ganttData: any[] = this.data().map(n => {\n const ret = [...n];\n ret[1] = isNaN(n[1] as any) ? new Date(n[1]).getTime() : Number(n[1]);\n ret[2] = isNaN(n[2] as any) ? new Date(n[2]).getTime() : Number(n[2]);\n return ret;\n });\n\n this._gantt._minStart = d3Min(ganttData, n => n[1]);\n this._gantt._maxEnd = d3Max(ganttData, n => n[2]);\n this._gantt.data(ganttData);\n }\n return retVal;\n }\n\n resize(_size?: { width: number, height: number }) {\n const retVal = super.resize.apply(this, arguments);\n\n if (this._topAxisElement) {\n this.resizeWrappers();\n }\n\n return retVal;\n }\n\n click(row, col, sel) {\n\n }\n\n dblclick(row, col, sel) {\n\n }\n\n tooltip() {\n return this._gantt._tooltip;\n }\n}\nReactAxisGanttSeries.prototype._class += \" timeline_ReactAxisGanttSeries\";\n\nexport interface ReactAxisGanttSeries {\n tickFormat(): string;\n tickFormat(_: string): this;\n tickFormat_exists(): boolean;\n overlapTolerence(): number;\n overlapTolerence(_: number): this;\n smallestRangeWidth(): number;\n smallestRangeWidth(_: number): this;\n scaleMode(): boolean;\n scaleMode(_: boolean): this;\n fontSize(): number;\n fontSize(_: number): this;\n fontFamily(): string;\n fontFamily(_: string): this;\n strokeWidth(): number;\n strokeWidth(_: number): this;\n stroke(): string;\n stroke(_: string): this;\n cornerRadius(): number;\n cornerRadius(_: number): this;\n axisFontSize(): number;\n axisFontSize(_: number): this;\n axisFontFamily(): string;\n axisFontFamily(_: string): this;\n axisTickLength(): number;\n axisTickLength(_: number): this;\n axisHeight(): number;\n axisHeight(_: number): this;\n titleColumn(): string;\n titleColumn(_: string): this;\n startDateColumn(): string;\n startDateColumn(_: string): this;\n endDateColumn(): string;\n endDateColumn(_: string): this;\n iconColumn(): string;\n iconColumn(_: string): this;\n colorColumn(): string;\n colorColumn(_: string): this;\n seriesColumn(): string;\n seriesColumn(_: string): this;\n bucketColumn(): string;\n bucketColumn(_: string): this;\n maxZoom(): number;\n maxZoom(_: number): this;\n}\nReactAxisGanttSeries.prototype.publish(\"tickFormat\", null, \"string\", \"Format rule applied to axis tick labels\", undefined, { optional: true });\nReactAxisGanttSeries.prototype.publish(\"axisHeight\", 22, \"number\", \"Height of axes (pixels)\");\nReactAxisGanttSeries.prototype.publish(\"overlapTolerence\", 2, \"number\", \"overlapTolerence\");\nReactAxisGanttSeries.prototype.publish(\"smallestRangeWidth\", 10, \"number\", \"Width of the shortest range (pixels)\");\nReactAxisGanttSeries.prototype.publish(\"axisFontSize\", null, \"number\", \"Font size of axis tick labels\");\nReactAxisGanttSeries.prototype.publish(\"axisFontFamily\", null, \"string\", \"Font family of axis tick labels\");\nReactAxisGanttSeries.prototype.publish(\"axisTickLength\", null, \"number\", \"Length of axis ticks\");\nReactAxisGanttSeries.prototype.publishProxy(\"gutter\", \"_gantt\");\nReactAxisGanttSeries.prototype.publishProxy(\"renderMode\", \"_gantt\");\nReactAxisGanttSeries.prototype.publishProxy(\"strokeWidth\", \"_gantt\");\nReactAxisGanttSeries.prototype.publishProxy(\"fontSize\", \"_gantt\");\nReactAxisGanttSeries.prototype.publishProxy(\"fontFamily\", \"_gantt\");\nReactAxisGanttSeries.prototype.publishProxy(\"stroke\", \"_gantt\");\nReactAxisGanttSeries.prototype.publishProxy(\"cornerRadius\", \"_gantt\");\nReactAxisGanttSeries.prototype.publishProxy(\"titleColumn\", \"_gantt\");\nReactAxisGanttSeries.prototype.publishProxy(\"startDateColumn\", \"_gantt\");\nReactAxisGanttSeries.prototype.publishProxy(\"endDateColumn\", \"_gantt\");\nReactAxisGanttSeries.prototype.publishProxy(\"iconColumn\", \"_gantt\");\nReactAxisGanttSeries.prototype.publishProxy(\"colorColumn\", \"_gantt\");\nReactAxisGanttSeries.prototype.publishProxy(\"seriesColumn\", \"_gantt\");\nReactAxisGanttSeries.prototype.publishProxy(\"bucketColumn\", \"_gantt\");\nReactAxisGanttSeries.prototype.publishProxy(\"maxZoom\", \"_gantt\");\nReactAxisGanttSeries.prototype.publishProxy(\"evenSeriesBackground\", \"_gantt\");\nReactAxisGanttSeries.prototype.publishProxy(\"oddSeriesBackground\", \"_gantt\");\nReactAxisGanttSeries.prototype.publishProxy(\"bucketHeight\", \"_gantt\");\n","import { timeFormat as d3TimeFormat, timeParse as d3TimeParse } from \"d3-time-format\";\nimport { ReactAxisGantt } from \"./ReactAxisGantt.ts\";\n\nexport class ReactTimeline extends ReactAxisGantt {\n\n protected _axisLabelFormatter;//TODO: add a type to this? d3 time formatting function type?\n\n constructor() {\n super();\n this._drawStartPos = \"origin\";\n this._topAxis.type(\"time\");\n this._bottomAxis.type(\"time\");\n\n this.tooltipHTML((d: any) => {\n const parser = d3TimeParse(\"%Q\");\n const startTime = parser(d[1]);\n const endTime = parser(d[2]);\n\n const formatter = d3TimeFormat(this.tooltipTimeFormat());\n return `<div style=\"text-align:center;\">${d[0]}<br/><br/>${formatter(startTime)} -> ${formatter(endTime)}</div>`;\n });\n }\n\n update(domNode, element) {\n super.update(domNode, element);\n\n if (this.timePattern_exists()) {\n\n let minTimestamp = Infinity;\n let maxTimestamp = -Infinity;\n let lowDateStr = \"\";\n let highDateStr = \"\";\n this.data().map(n => {\n const start = new Date(n[1]).getTime();\n const end = new Date(n[2]).getTime();\n if (minTimestamp > start) {\n minTimestamp = start;\n lowDateStr = \"\" + n[1];\n }\n if (maxTimestamp < end) {\n maxTimestamp = end;\n highDateStr = \"\" + n[2];\n }\n });\n\n const axisTickFormat = this._axisLabelFormatter\n ? this._axisLabelFormatter\n : (this.tickFormat_exists && this.tickFormat_exists() ? this.tickFormat() : undefined);\n\n this._topAxis\n .type(\"time\")\n .timePattern(this.timePattern())\n .overlapMode(\"none\")\n .low(lowDateStr)\n .high(highDateStr)\n ;\n this._bottomAxis\n .type(\"time\")\n .timePattern(this.timePattern())\n .overlapMode(\"none\")\n .low(lowDateStr)\n .high(highDateStr)\n ;\n\n if (axisTickFormat) {\n this._topAxis.tickFormat(axisTickFormat);\n this._bottomAxis.tickFormat(axisTickFormat);\n } else {\n this._topAxis.tickFormat_reset();\n this._bottomAxis.tickFormat_reset();\n }\n this._gantt._minStart = minTimestamp;\n this._gantt._maxEnd = maxTimestamp;\n }\n }\n\n tooltipHTML(callback) {\n this._tooltipHTML = callback;\n this.tooltip().tooltipHTML(this._tooltipHTML);\n return this;\n }\n\n parseAxisValue(v) {\n const parseTime = d3TimeParse(\"%Q\");\n const parsedTime = parseTime(v);\n\n const formatTime = d3TimeFormat(this.timePattern());\n return formatTime(parsedTime);\n }\n\n onzoom(transform) {\n\n const w = this.width();\n const low = this._gantt._minStart;\n const high = this._gantt._maxEnd;\n const range = high - low;\n const wpp = range / w;\n const nextLow = Math.floor(low - (wpp * (transform.x / transform.k)));\n const nextHigh = Math.ceil((range / transform.k) + nextLow);\n\n this._topAxis\n .low(this.parseAxisValue(nextLow))\n .high(this.parseAxisValue(nextHigh))\n .render()\n ;\n this._bottomAxis\n .low(this.parseAxisValue(nextLow))\n .high(this.parseAxisValue(nextHigh))\n .render()\n ;\n }\n}\nReactTimeline.prototype._class += \" timeline_ReactTimeline\";\n\nexport interface ReactTimeline {\n _tooltipHTML(_): string;\n\n timePattern(): string;\n timePattern(_: string): this;\n timePattern_exists(): boolean;\n tooltipTimeFormat(): string;\n tooltipTimeFormat(_: string): this;\n}\nReactTimeline.prototype.publish(\"timePattern\", \"%Y-%m-%d\", \"string\", \"Time pattern used for parsing datetime strings on each data row\", null, { optional: true });\nReactTimeline.prototype.publish(\"tooltipTimeFormat\", \"%Y-%m-%d\", \"string\", \"Time format used in the default html tooltip\");\n\n","import { timeFormat as d3TimeFormat, timeParse as d3TimeParse } from \"d3-time-format\";\nimport { ReactAxisGanttSeries } from \"./ReactAxisGanttSeries.ts\";\n\nconst parseTime = d3TimeParse(\"%Q\");\nexport class ReactTimelineSeries extends ReactAxisGanttSeries {\n\n protected _axisLabelFormatter;//TODO: add a type to this? d3 time formatting function type?\n\n constructor() {\n super();\n this._topAxis.type(\"time\");\n this._bottomAxis.type(\"time\");\n\n this.tooltipHTML((d: any) => {\n const startTime = parseTime(d[1]);\n const endTime = parseTime(d[2]);\n\n const formatter = d3TimeFormat(this.tooltipTimeFormat());\n return `<div style=\"text-align:center;\">${d[0]}<br/><br/>${formatter(startTime)} -> ${formatter(endTime)}</div>`;\n });\n }\n\n update(domNode, element) {\n super.update(domNode, element);\n\n if (this.timePattern_exists()) {\n\n let minTimestamp = Infinity;\n let maxTimestamp = -Infinity;\n let lowDateStr = \"\";\n let highDateStr = \"\";\n this.data().forEach(n => {\n const start = new Date(n[1]).getTime();\n const end = new Date(n[2]).getTime();\n if (minTimestamp > start) {\n minTimestamp = start;\n lowDateStr = \"\" + n[1];\n }\n if (maxTimestamp < end) {\n maxTimestamp = end;\n highDateStr = \"\" + n[2];\n }\n });\n\n const axisTickFormat = this._axisLabelFormatter\n ? this._axisLabelFormatter\n : (this.tickFormat_exists && this.tickFormat_exists() ? this.tickFormat() : undefined);\n\n this._topAxis\n .type(\"time\")\n .timePattern(this.timePattern())\n .overlapMode(\"none\")\n .low(lowDateStr)\n .high(highDateStr)\n ;\n this._bottomAxis\n .type(\"time\")\n .timePattern(this.timePattern())\n .overlapMode(\"none\")\n .low(lowDateStr)\n .high(highDateStr)\n ;\n\n if (axisTickFormat) {\n this._topAxis.tickFormat(axisTickFormat);\n this._bottomAxis.tickFormat(axisTickFormat);\n } else {\n this._topAxis.tickFormat_reset();\n this._bottomAxis.tickFormat_reset();\n }\n this._gantt._minStart = minTimestamp;\n this._gantt._maxEnd = maxTimestamp;\n }\n }\n\n tooltipHTML(callback) {\n this._tooltipHTML = callback;\n this.tooltip().tooltipHTML(this._tooltipHTML);\n return this;\n }\n\n parseAxisValue(v) {\n const parsedTime = parseTime(v);\n\n const formatTime = d3TimeFormat(this.timePattern());\n return formatTime(parsedTime);\n }\n\n onzoom(transform) {\n\n const w = this.width();\n const low = this._gantt._minStart;\n const high = this._gantt._maxEnd;\n const range = high - low;\n const wpp = range / w;\n const nextLow = Math.floor(low - (wpp * (transform.x / transform.k)));\n const nextHigh = Math.ceil((range / transform.k) + nextLow);\n\n this._topAxis\n .low(this.parseAxisValue(nextLow))\n .high(this.parseAxisValue(nextHigh))\n .render()\n ;\n this._bottomAxis\n .low(this.parseAxisValue(nextLow))\n .high(this.parseAxisValue(nextHigh))\n .render()\n ;\n }\n\n _tooltipHTML: (_) => string;\n}\nReactTimelineSeries.prototype._class += \" timeline_ReactTimelineSeries\";\n\nexport interface ReactTimelineSeries {\n timePattern(): string;\n timePattern(_: string): this;\n timePattern_exists(): boolean;\n tooltipTimeFormat(): string;\n tooltipTimeFormat(_: string): this;\n}\nReactTimelineSeries.prototype.publish(\"timePattern\", \"%Y-%m-%d\", \"string\", \"Time pattern used for parsing datetime strings on each data row\", null, { optional: true });\nReactTimelineSeries.prototype.publish(\"tooltipTimeFormat\", \"%Y-%m-%d\", \"string\", \"Time format used in the default html tooltip\");\n\n"],"mappings":"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"}
|