Skip to content
This repository has been archived by the owner on Jan 29, 2021. It is now read-only.

Commit

Permalink
New: Timeline API x-axis y-coordinates property(fixes #238)
Browse files Browse the repository at this point in the history
  • Loading branch information
AshishMotanamGurunadham committed Oct 9, 2020
1 parent 9e61293 commit af86658
Show file tree
Hide file tree
Showing 7 changed files with 114 additions and 11 deletions.
2 changes: 2 additions & 0 deletions docs/controls/Timeline.md
Original file line number Diff line number Diff line change
Expand Up @@ -100,6 +100,8 @@ timelineDefault.loadContent(/* Data array D */);
| showLabel | boolean | true | Toggle to show X axis label |
| showLegend | boolean | true | Toggle to show graph legend |
| throttle | number | (1000/60) => time in ms | Delay between resize of a browser window |
| axisYPosition | number | undefined | Sets the position of axis in y direction |


### Axis

Expand Down
8 changes: 5 additions & 3 deletions src/main/js/controls/Timeline/Timeline.js
Original file line number Diff line number Diff line change
Expand Up @@ -55,9 +55,11 @@ const setCanvasWidth = (container, config) => {
* @returns {undefined} - returns nothing
*/
const setCanvasHeight = (config) => {
config.canvasHeight =
getYAxisHeight(config) +
(config.padding.bottom * 2 + config.padding.top) * 2;
config.canvasHeight = config.axisYPosition ?
(getYAxisHeight(config) +
(config.padding.bottom * 2 + config.padding.top) * 2 + config.axisYPosition) : getYAxisHeight(config) +
(config.padding.bottom * 2 + config.padding.top) * 2 ;
return config.canvasHeight;
};
/**
* Data point sets can be loaded using this function.
Expand Down
4 changes: 4 additions & 0 deletions src/main/js/controls/Timeline/TimelineConfig.js
Original file line number Diff line number Diff line change
Expand Up @@ -81,6 +81,7 @@ export const processInput = (input, config) => {
rangeRounding: getDefaultValue(_axis.x.rangeRounding, true)
});
config.shownTargets = [];
config.axisYPosition = input.axisYPosition;
return config;
};

Expand Down Expand Up @@ -170,6 +171,9 @@ class TimelineConfig extends BaseConfig {
) {
throw new Error(errors.THROW_MSG_INVALID_AXIS_TYPE_VALUES);
}
if (utils.isDefined(this.input.axisYPosition) && this.input.axisYPosition < 0) {
throw new Error(errors.THROW_MSG_AXIS_Y_POSITION_CANNOT_BE_NEGATIVE);
}
return this;
}

Expand Down
21 changes: 15 additions & 6 deletions src/main/js/controls/Timeline/helpers/creationHelpers.js
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,7 @@ import {
getShapeForTarget
} from "../../Graph/helpers/helpers";
import { transformPoint } from "./translateHelpers";
import { getDefaultValue } from "../../../core/BaseConfig";

/**
* @typedef TimelineContent
Expand Down Expand Up @@ -119,10 +120,18 @@ const getXAxisLabelXPosition = (config) =>
* @param {object} config - config object derived from input JSON
* @returns {number} Position for the label
*/
const getXAxisLabelYPosition = (config) =>
getXAxisYPosition(config) +
config.axisLabelHeights.x * 2 +
config.padding.bottom * 4;
const getXAxisLabelYPosition = (config) => {
const defaultLabelPosition = getXAxisYPosition(config) +
config.axisLabelHeights.x * 2 +
config.padding.bottom * 4;
if(utils.isUndefined(config.axisYPosition) || (defaultLabelPosition > getXAxisYPosition(config) +
config.axisLabelHeights.x * 2 + config.axisYPosition )) {
return defaultLabelPosition;
} else {
return getXAxisYPosition(config) +
config.axisLabelHeights.x * 2 + config.axisYPosition + config.padding.bottom * 3
};
}
/**
* Prepares X,Y and Y2 Axes according to their scale and available container width and height
*
Expand Down Expand Up @@ -211,9 +220,9 @@ const createAxes = (axis, scale, config, canvasSVG) => {
.attr("aria-hidden", false)
.attr(
"transform",
`translate(${getXAxisXPosition(config)}, ${getXAxisYPosition(
`translate(${getXAxisXPosition(config)}, ${getDefaultValue(config.axisYPosition, getXAxisYPosition(
config
)})`
))})`
)
.call(axis.x);
};
Expand Down
5 changes: 3 additions & 2 deletions src/main/js/controls/Timeline/helpers/translateHelpers.js
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ import {
getXAxisXPosition,
getXAxisYPosition
} from "./creationHelpers";
import { getDefaultValue } from "../../../core/BaseConfig";

/**
* Updates clipPath rectangle width and height on resize.
Expand Down Expand Up @@ -48,9 +49,9 @@ const translateAxes = (axis, scale, config, canvasSVG) => {
.call(constants.d3Transition(config.settingsDictionary.transition))
.attr(
"transform",
`translate(${getXAxisXPosition(config)},${getXAxisYPosition(
`translate(${getXAxisXPosition(config)},${getDefaultValue(config.axisYPosition, getXAxisYPosition(
config
)})`
))})`
)
.call(axis.x);
};
Expand Down
1 change: 1 addition & 0 deletions src/main/js/helpers/errors.js
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,7 @@ export default {
THROW_MSG_UNIQUE_LABEL_NOT_PROVIDED:
"Invalid input format, unique label must be provided.",
THROW_MSG_NO_CONTENT_DATA_LOADED: "Content data needs to be loaded.",
THROW_MSG_AXIS_Y_POSITION_CANNOT_BE_NEGATIVE: "Axis Y position cannot be negative.",
/**
* @description Axes
*/
Expand Down
84 changes: 84 additions & 0 deletions src/test/unit/controls/Timeline/TimelineLoad-spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@ import {
secondaryValuesJSON,
valuesJSON
} from "./helpers";
import { getSVGAnimatedTransformList } from "../../../../main/js/helpers/transformUtils";

describe("Timeline - Load", () => {
let input;
Expand Down Expand Up @@ -127,6 +128,17 @@ describe("Timeline - Load", () => {
timeline.loadContent(getData(valuesJSON));
}).toThrowError(errors.THROW_MSG_UNIQUE_KEY_NOT_PROVIDED);
});
it("Throws error for when axisYPosition value is less than 0", () => {
expect(() => {
timeline = new Timeline(
Object.assign(
{
axisYPosition : -1
},
getAxes(axisJSON)
));
}).toThrowError(errors.THROW_MSG_AXIS_Y_POSITION_CANNOT_BE_NEGATIVE);
});
});
it("Clones the input object correctly", () => {
expect(timeline.contentConfig[0].config.key).toBe(input.key);
Expand Down Expand Up @@ -213,6 +225,78 @@ describe("Timeline - Load", () => {
(config.padding.top + config.padding.bottom) * 2
);
});
describe("When axisYPosition is provided", () => {
beforeEach(() => {
timeline.destroy();
input = getData(valuesJSON);
const config = getAxes(axisJSON);
timeline = new Timeline(
Object.assign(
{
axisYPosition : 10,
},
config
));
timeline.loadContent(input);
});
it("check position of axis in container", () => {
const axisGroup = document.querySelector(
`.${styles.axisX}`
);
const translate = getSVGAnimatedTransformList(
axisGroup.getAttribute("transform")
).translate;
expect(translate[1]).toEqual(
timeline.config.axisYPosition
);
});
it("check height of graph container", () => {
const canvas = d3.select(`.${styles.canvas}`);
const canvasHeight =
getYAxisHeight(timeline.config) +
(timeline.config.padding.bottom * 2 + timeline.config.padding.top) * 2 + timeline.config.axisYPosition;
expect(toNumber(canvas.attr("height"))).toEqual(canvasHeight);
});
describe("check position of label", () => {
it(" when axisYPosition is small", () => {
const labelGroup = document.querySelector(
`.${styles.axisLabelX}`
);
const translate = getSVGAnimatedTransformList(
labelGroup.getAttribute("transform")
).translate;
expect(translate[1]).toEqual(
getXAxisYPosition(timeline.config) +
timeline.config.axisLabelHeights.x * 2 +
timeline.config.padding.bottom * 4
);
});
it(" when axisYPosition is large", () => {
timeline.destroy();
input = getData(valuesJSON);
const config = getAxes(axisJSON);
timeline = new Timeline(
Object.assign(
{
axisYPosition : 100,
},
config
));
timeline.loadContent(input);
const labelGroup = document.querySelector(
`.${styles.axisLabelX}`
);
const translate = getSVGAnimatedTransformList(
labelGroup.getAttribute("transform")
).translate;
expect(translate[1]).toEqual(
getXAxisYPosition(timeline.config) +
timeline.config.axisLabelHeights.x * 2 +
timeline.config.padding.bottom * 3 + timeline.config.axisYPosition
);
});
});
});
describe("Draws the graph", () => {
let input = null;
let secondaryInput = null;
Expand Down

0 comments on commit af86658

Please sign in to comment.