scroll changes + hour view fix

This commit is contained in:
lisaavikarii 2022-05-29 10:56:25 +02:00
parent 84298ecda6
commit 0aed9cbe72
15 changed files with 13676 additions and 35791 deletions

View File

@ -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

File diff suppressed because it is too large Load Diff

View File

@ -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": [

View File

@ -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);
}) });

View File

@ -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,

View File

@ -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

File diff suppressed because it is too large Load Diff

View File

@ -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"

View File

@ -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}

View File

@ -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);
}; };
/** /**

View File

@ -186,6 +186,10 @@ export const TaskGanttContent: React.FC<TaskGanttContentProps> = ({
onDateChange, onDateChange,
svg, svg,
isMoving, isMoving,
point,
rtl,
setFailedTask,
setGanttEvent,
]); ]);
/** /**

View File

@ -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;
}

View File

@ -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>
); );
}; };

View File

@ -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 (

View File

@ -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;
}