scroll changes + hour view fix
This commit is contained in:
parent
84298ecda6
commit
0aed9cbe72
@ -1,13 +1,6 @@
|
|||||||
{
|
{
|
||||||
"parser": "@typescript-eslint/parser",
|
"parser": "@typescript-eslint/parser",
|
||||||
"extends": [
|
"extends": ["react-app", "react-app/jest"],
|
||||||
"standard",
|
|
||||||
"standard-react",
|
|
||||||
"plugin:prettier/recommended",
|
|
||||||
"prettier/standard",
|
|
||||||
"prettier/react",
|
|
||||||
"plugin:@typescript-eslint/eslint-recommended"
|
|
||||||
],
|
|
||||||
"plugins": ["@typescript-eslint"],
|
"plugins": ["@typescript-eslint"],
|
||||||
"env": {
|
"env": {
|
||||||
"node": true
|
"node": true
|
||||||
|
|||||||
28711
example/package-lock.json
generated
28711
example/package-lock.json
generated
File diff suppressed because it is too large
Load Diff
@ -24,7 +24,6 @@
|
|||||||
"react-scripts": "file:../node_modules/react-scripts"
|
"react-scripts": "file:../node_modules/react-scripts"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@babel/plugin-syntax-object-rest-spread": "^7.8.3"
|
|
||||||
},
|
},
|
||||||
"browserslist": {
|
"browserslist": {
|
||||||
"production": [
|
"production": [
|
||||||
|
|||||||
@ -1,9 +1,9 @@
|
|||||||
import React from 'react'
|
import React from "react";
|
||||||
import ReactDOM from 'react-dom'
|
import ReactDOM from "react-dom";
|
||||||
import App from './App'
|
import App from "./App";
|
||||||
|
|
||||||
it('renders without crashing', () => {
|
it("renders without crashing", () => {
|
||||||
const div = document.createElement('div')
|
const div = document.createElement("div");
|
||||||
ReactDOM.render(<App />, div)
|
ReactDOM.render(<App />, div);
|
||||||
ReactDOM.unmountComponentAtNode(div)
|
ReactDOM.unmountComponentAtNode(div);
|
||||||
})
|
});
|
||||||
|
|||||||
@ -6,7 +6,7 @@ type ViewSwitcherProps = {
|
|||||||
onViewListChange: (isChecked: boolean) => void;
|
onViewListChange: (isChecked: boolean) => void;
|
||||||
onViewModeChange: (viewMode: ViewMode) => void;
|
onViewModeChange: (viewMode: ViewMode) => void;
|
||||||
};
|
};
|
||||||
export const ViewSwitcher: React.SFC<ViewSwitcherProps> = ({
|
export const ViewSwitcher: React.FC<ViewSwitcherProps> = ({
|
||||||
onViewModeChange,
|
onViewModeChange,
|
||||||
onViewListChange,
|
onViewListChange,
|
||||||
isChecked,
|
isChecked,
|
||||||
|
|||||||
@ -1,7 +1,9 @@
|
|||||||
import "./index.css";
|
import "./index.css";
|
||||||
|
|
||||||
import React from "react";
|
import React from "react";
|
||||||
import ReactDOM from "react-dom";
|
import { createRoot } from "react-dom/client";
|
||||||
import App from "./App";
|
import App from "./App";
|
||||||
|
|
||||||
ReactDOM.render(<App />, document.getElementById("root"));
|
const container = document.getElementById("root");
|
||||||
|
const root = createRoot(container!);
|
||||||
|
root.render(<App />);
|
||||||
|
|||||||
20603
package-lock.json
generated
20603
package-lock.json
generated
File diff suppressed because it is too large
Load Diff
28
package.json
28
package.json
@ -36,7 +36,7 @@
|
|||||||
"deploy": "gh-pages -d example/build"
|
"deploy": "gh-pages -d example/build"
|
||||||
},
|
},
|
||||||
"peerDependencies": {
|
"peerDependencies": {
|
||||||
"react": "^17.0.2"
|
"react": "^18.0.0"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@testing-library/jest-dom": "^5.12.0",
|
"@testing-library/jest-dom": "^5.12.0",
|
||||||
@ -44,33 +44,21 @@
|
|||||||
"@testing-library/user-event": "^13.1.8",
|
"@testing-library/user-event": "^13.1.8",
|
||||||
"@types/jest": "^26.0.23",
|
"@types/jest": "^26.0.23",
|
||||||
"@types/node": "^15.0.1",
|
"@types/node": "^15.0.1",
|
||||||
"@types/react": "^17.0.38",
|
"@types/react": "^18.0.5",
|
||||||
"@types/react-dom": "^17.0.11",
|
"@types/react-dom": "^18.0.1",
|
||||||
"@typescript-eslint/eslint-plugin": "^5.10.0",
|
|
||||||
"@typescript-eslint/parser": "^5.9.1",
|
|
||||||
"babel-eslint": "^10.0.3",
|
|
||||||
"cross-env": "^7.0.3",
|
"cross-env": "^7.0.3",
|
||||||
"eslint-config-prettier": "^6.15.0",
|
|
||||||
"eslint-config-standard": "^16.0.3",
|
|
||||||
"eslint-config-standard-react": "^9.2.0",
|
|
||||||
"eslint-plugin-import": "^2.22.1",
|
|
||||||
"eslint-plugin-node": "^11.0.0",
|
|
||||||
"eslint-plugin-prettier": "^4.0.0",
|
|
||||||
"eslint-plugin-promise": "^5.2.0",
|
|
||||||
"eslint-plugin-react": "^7.22.0",
|
|
||||||
"eslint-plugin-standard": "^4.1.0",
|
|
||||||
"gh-pages": "^3.1.0",
|
"gh-pages": "^3.1.0",
|
||||||
"microbundle-crl": "^0.13.11",
|
"microbundle-crl": "^0.13.11",
|
||||||
"mini-css-extract-plugin": "^2.5.1",
|
"mini-css-extract-plugin": "^2.5.1",
|
||||||
"npm-run-all": "^4.1.5",
|
"npm-run-all": "^4.1.5",
|
||||||
"postcss-flexbugs-fixes": "^5.0.2",
|
"postcss-flexbugs-fixes": "^5.0.2",
|
||||||
"postcss-normalize": "^10.0.1",
|
"postcss-normalize": "^10.0.1",
|
||||||
"postcss-preset-env": "^7.2.3",
|
"postcss-preset-env": "^7.6.0",
|
||||||
"prettier": "^2.5.1",
|
"prettier": "^2.5.1",
|
||||||
"react": "^17.0.2",
|
"react": "^18.1.0",
|
||||||
"react-dom": "^17.0.2",
|
"react-dom": "^18.1.0",
|
||||||
"react-scripts": "^5.0.0",
|
"react-scripts": "^5.0.1",
|
||||||
"typescript": "^4.5.4"
|
"typescript": "^4.6.4"
|
||||||
},
|
},
|
||||||
"files": [
|
"files": [
|
||||||
"dist"
|
"dist"
|
||||||
|
|||||||
@ -241,16 +241,17 @@ export const Calendar: React.FC<CalendarProps> = ({
|
|||||||
{bottomValue}
|
{bottomValue}
|
||||||
</text>
|
</text>
|
||||||
);
|
);
|
||||||
if (i === 0 || date.getDate() !== dates[i - 1].getDate()) {
|
if (i !== 0 && date.getDate() !== dates[i - 1].getDate()) {
|
||||||
|
const displayDate = dates[i - 1];
|
||||||
const topValue = `${getLocalDayOfWeek(
|
const topValue = `${getLocalDayOfWeek(
|
||||||
date,
|
displayDate,
|
||||||
locale,
|
locale,
|
||||||
"long"
|
"long"
|
||||||
)}, ${date.getDate()} ${getLocaleMonth(date, locale)}`;
|
)}, ${displayDate.getDate()} ${getLocaleMonth(displayDate, locale)}`;
|
||||||
const topPosition = (date.getHours() - 24) / 2;
|
const topPosition = (date.getHours() - 24) / 2;
|
||||||
topValues.push(
|
topValues.push(
|
||||||
<TopPartOfCalendar
|
<TopPartOfCalendar
|
||||||
key={topValue + date.getFullYear()}
|
key={topValue + displayDate.getFullYear()}
|
||||||
value={topValue}
|
value={topValue}
|
||||||
x1Line={columnWidth * i}
|
x1Line={columnWidth * i}
|
||||||
y1Line={0}
|
y1Line={0}
|
||||||
|
|||||||
@ -183,6 +183,7 @@ export const Gantt: React.FunctionComponent<GanttProps> = ({
|
|||||||
viewDate,
|
viewDate,
|
||||||
columnWidth,
|
columnWidth,
|
||||||
dateSetup.dates,
|
dateSetup.dates,
|
||||||
|
dateSetup.viewMode,
|
||||||
viewMode,
|
viewMode,
|
||||||
currentViewDate,
|
currentViewDate,
|
||||||
setCurrentViewDate,
|
setCurrentViewDate,
|
||||||
@ -245,7 +246,7 @@ export const Gantt: React.FunctionComponent<GanttProps> = ({
|
|||||||
} else {
|
} else {
|
||||||
setSvgContainerHeight(tasks.length * rowHeight + headerHeight);
|
setSvgContainerHeight(tasks.length * rowHeight + headerHeight);
|
||||||
}
|
}
|
||||||
}, [ganttHeight, tasks]);
|
}, [ganttHeight, tasks, headerHeight, rowHeight]);
|
||||||
|
|
||||||
// scroll events
|
// scroll events
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
@ -287,20 +288,32 @@ export const Gantt: React.FunctionComponent<GanttProps> = ({
|
|||||||
wrapperRef.current.removeEventListener("wheel", handleWheel);
|
wrapperRef.current.removeEventListener("wheel", handleWheel);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
}, [wrapperRef.current, scrollY, scrollX, ganttHeight, svgWidth, rtl]);
|
}, [
|
||||||
|
wrapperRef,
|
||||||
|
scrollY,
|
||||||
|
scrollX,
|
||||||
|
ganttHeight,
|
||||||
|
svgWidth,
|
||||||
|
rtl,
|
||||||
|
ganttFullHeight,
|
||||||
|
]);
|
||||||
|
|
||||||
const handleScrollY = (event: SyntheticEvent<HTMLDivElement>) => {
|
const handleScrollY = (event: SyntheticEvent<HTMLDivElement>) => {
|
||||||
if (scrollY !== event.currentTarget.scrollTop && !ignoreScrollEvent) {
|
if (scrollY !== event.currentTarget.scrollTop && !ignoreScrollEvent) {
|
||||||
setScrollY(event.currentTarget.scrollTop);
|
setScrollY(event.currentTarget.scrollTop);
|
||||||
|
setIgnoreScrollEvent(true);
|
||||||
|
} else {
|
||||||
|
setIgnoreScrollEvent(false);
|
||||||
}
|
}
|
||||||
setIgnoreScrollEvent(false);
|
|
||||||
};
|
};
|
||||||
|
|
||||||
const handleScrollX = (event: SyntheticEvent<HTMLDivElement>) => {
|
const handleScrollX = (event: SyntheticEvent<HTMLDivElement>) => {
|
||||||
if (scrollX !== event.currentTarget.scrollLeft && !ignoreScrollEvent) {
|
if (scrollX !== event.currentTarget.scrollLeft && !ignoreScrollEvent) {
|
||||||
setScrollX(event.currentTarget.scrollLeft);
|
setScrollX(event.currentTarget.scrollLeft);
|
||||||
|
setIgnoreScrollEvent(true);
|
||||||
|
} else {
|
||||||
|
setIgnoreScrollEvent(false);
|
||||||
}
|
}
|
||||||
setIgnoreScrollEvent(false);
|
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@ -186,6 +186,10 @@ export const TaskGanttContent: React.FC<TaskGanttContentProps> = ({
|
|||||||
onDateChange,
|
onDateChange,
|
||||||
svg,
|
svg,
|
||||||
isMoving,
|
isMoving,
|
||||||
|
point,
|
||||||
|
rtl,
|
||||||
|
setFailedTask,
|
||||||
|
setGanttEvent,
|
||||||
]);
|
]);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@ -1,4 +1,32 @@
|
|||||||
.scroll {
|
.scrollWrapper {
|
||||||
overflow: auto;
|
overflow: auto;
|
||||||
max-width: 100%;
|
max-width: 100%;
|
||||||
}
|
}
|
||||||
|
.scrollWrapper::-webkit-scrollbar {
|
||||||
|
width: 1.1rem;
|
||||||
|
height: 1.1rem;
|
||||||
|
}
|
||||||
|
.scrollWrapper::-webkit-scrollbar-corner {
|
||||||
|
background: transparent;
|
||||||
|
}
|
||||||
|
.scrollWrapper::-webkit-scrollbar-thumb {
|
||||||
|
border: 6px solid transparent;
|
||||||
|
background: rgba(0, 0, 0, 0.2);
|
||||||
|
background: var(--palette-black-alpha-20, rgba(0, 0, 0, 0.2));
|
||||||
|
border-radius: 10px;
|
||||||
|
background-clip: padding-box;
|
||||||
|
}
|
||||||
|
.scrollWrapper::-webkit-scrollbar-thumb:hover {
|
||||||
|
border: 4px solid transparent;
|
||||||
|
background: rgba(0, 0, 0, 0.3);
|
||||||
|
background: var(--palette-black-alpha-30, rgba(0, 0, 0, 0.3));
|
||||||
|
background-clip: padding-box;
|
||||||
|
}
|
||||||
|
@media only screen and (max-device-width: 1024px) and (-webkit-min-device-pixel-ratio: 2) {
|
||||||
|
.scrollWrapper {
|
||||||
|
-webkit-overflow-scrolling: touch;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.scroll {
|
||||||
|
height: 1px;
|
||||||
|
}
|
||||||
|
|||||||
@ -24,11 +24,11 @@ export const HorizontalScroll: React.FC<{
|
|||||||
? `0px ${taskListWidth}px 0px 0px`
|
? `0px ${taskListWidth}px 0px 0px`
|
||||||
: `0px 0px 0px ${taskListWidth}px`,
|
: `0px 0px 0px ${taskListWidth}px`,
|
||||||
}}
|
}}
|
||||||
className={styles.scroll}
|
className={styles.scrollWrapper}
|
||||||
onScroll={onScroll}
|
onScroll={onScroll}
|
||||||
ref={scrollRef}
|
ref={scrollRef}
|
||||||
>
|
>
|
||||||
<div style={{ width: svgWidth, height: 1 }} />
|
<div style={{ width: svgWidth }} className={styles.scroll} />
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|||||||
@ -84,7 +84,7 @@ export const Tooltip: React.FC<TooltipProps> = ({
|
|||||||
setRelatedX(newRelatedX);
|
setRelatedX(newRelatedX);
|
||||||
}
|
}
|
||||||
}, [
|
}, [
|
||||||
tooltipRef.current,
|
tooltipRef,
|
||||||
task,
|
task,
|
||||||
arrowIndent,
|
arrowIndent,
|
||||||
scrollX,
|
scrollX,
|
||||||
@ -94,6 +94,7 @@ export const Tooltip: React.FC<TooltipProps> = ({
|
|||||||
rowHeight,
|
rowHeight,
|
||||||
svgContainerHeight,
|
svgContainerHeight,
|
||||||
svgContainerWidth,
|
svgContainerWidth,
|
||||||
|
rtl,
|
||||||
]);
|
]);
|
||||||
|
|
||||||
return (
|
return (
|
||||||
|
|||||||
@ -3,3 +3,23 @@
|
|||||||
width: 17px;
|
width: 17px;
|
||||||
flex-shrink: 0;
|
flex-shrink: 0;
|
||||||
}
|
}
|
||||||
|
.scroll::-webkit-scrollbar {
|
||||||
|
width: 1.1rem;
|
||||||
|
height: 1.1rem;
|
||||||
|
}
|
||||||
|
.scroll::-webkit-scrollbar-corner {
|
||||||
|
background: transparent;
|
||||||
|
}
|
||||||
|
.scroll::-webkit-scrollbar-thumb {
|
||||||
|
border: 6px solid transparent;
|
||||||
|
background: rgba(0, 0, 0, 0.2);
|
||||||
|
background: var(--palette-black-alpha-20, rgba(0, 0, 0, 0.2));
|
||||||
|
border-radius: 10px;
|
||||||
|
background-clip: padding-box;
|
||||||
|
}
|
||||||
|
.scroll::-webkit-scrollbar-thumb:hover {
|
||||||
|
border: 4px solid transparent;
|
||||||
|
background: rgba(0, 0, 0, 0.3);
|
||||||
|
background: var(--palette-black-alpha-30, rgba(0, 0, 0, 0.3));
|
||||||
|
background-clip: padding-box;
|
||||||
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user