chore: renamed gantt key to gantt_chart

This commit is contained in:
gurusainath 2023-09-14 17:26:00 +05:30
parent 66022ea478
commit 28ce96aaca
11 changed files with 215 additions and 94 deletions

View File

@ -36,7 +36,7 @@ export const LayoutSelection = observer(() => {
icon: Columns, icon: Columns,
}, },
{ {
key: "gantt", key: "gantt_chart",
title: "Gantt", title: "Gantt",
icon: GanttChart, icon: GanttChart,
}, },

View File

@ -1,14 +1,36 @@
import React from "react"; import React from "react";
// mobx react lite // components
import { observer } from "mobx-react-lite"; import { IssueKanBanViewRoot } from "./kanban";
// mobx store import { LayoutSelection } from "./layout-selection";
import { RootStore } from "store/root"; import { IssueDropdown } from "./helpers/dropdown";
import { TIssueLayouts } from "store/issue-views/issue_filters"; import { FilterSelection } from "./filters";
import { useMobxStore } from "lib/mobx/store-provider"; import { DisplayFiltersSelection } from "./display-filters";
export const IssuesRoot = observer(() => { export const IssuesRoot = () => {
const store: RootStore = useMobxStore(); console.log("issue root");
const { issueFilters: issueFilterStore, issueView: issueStore } = store;
return <div>issue root</div>; return (
}); <div className="w-full h-full relative flex flex-col overflow-hidden">
<div className="flex-shrink-0 h-[60px] border-b border-gray-200">
<div className="w-full h-full p-2 px-5 relative flex justify-between items-center gap-2">
<div>
<div>Filter Header</div>
</div>
<div className="relative flex items-center gap-2">
<IssueDropdown title={"Filters"}>
<FilterSelection />
</IssueDropdown>
<IssueDropdown title={"View"}>
<DisplayFiltersSelection />
</IssueDropdown>
<LayoutSelection />
</div>
</div>
</div>
<div className="flex-shrink-0 border-b border-gray-200">Hello</div>
<div className="w-full h-full relative overflow-hidden">
<IssueKanBanViewRoot />
</div>
</div>
);
};

View File

@ -1,75 +0,0 @@
import React from "react";
// components
import { IssueKanBanViewRoot } from "components/issue-layouts/kanban";
import { LayoutSelection } from "components/issue-layouts/layout-selection";
// issue dropdowns
import { IssueDropdown } from "components/issue-layouts/helpers/dropdown";
// filter components
import { FilterSelection } from "components/issue-layouts/filters";
import { DisplayFiltersSelection } from "components/issue-layouts/display-filters";
// mobx store
import { useMobxStore } from "lib/mobx/store-provider";
import { RootStore } from "store/root";
const KanBanViewRoot = () => {
const workspaceSlug: string = "plane-demo";
const projectSlug: string = "08d59d96-9dfb-40e5-aa30-ecc66319450f";
const moduleSlug: string = "05613afc-29ea-4fd8-a025-a3cdfed209d1";
const cycleSlug: string = "1f66a767-00d1-422c-8f8f-6925282b7249";
const viewSlug: string = "64e6ecca-80ca-4f7c-8476-d650fca9d5b9";
const store: RootStore = useMobxStore();
const { issueFilters: issueFilterStore, issueView: issueViewStore } = store;
React.useEffect(() => {
const init = async () => {
console.log("started--->");
// my issues under a workspace
// await issueViewStore.getMyIssuesAsync(workspaceSlug);
// project issues under and workspace and project
await issueViewStore.getProjectIssuesAsync(workspaceSlug, projectSlug);
// module issues under and workspace and project
// await issueViewStore.getIssuesForModulesAsync(workspaceSlug, projectSlug, moduleSlug);
// cycle issues under and workspace and project
// await issueViewStore.getIssuesForCyclesAsync(workspaceSlug, projectSlug, cycleSlug);
// cycle issues under and workspace and project
// await issueViewStore.getIssuesForViewsAsync(workspaceSlug, projectSlug, viewSlug);
console.log("ended--->");
};
init();
}, []);
return (
<div className="w-screen min-h-[600px] h-screen">
<div className="w-full h-full relative flex flex-col overflow-hidden">
<div className="flex-shrink-0 h-[60px] border-b border-gray-200">
<div className="w-full h-full p-2 px-5 relative flex justify-between items-center gap-2">
<div>
<div>Filter Header</div>
</div>
<div className="relative flex items-center gap-2">
<IssueDropdown title={"Filters"}>
<FilterSelection />
</IssueDropdown>
<IssueDropdown title={"View"}>
<DisplayFiltersSelection />
</IssueDropdown>
<LayoutSelection />
</div>
</div>
</div>
<div className="flex-shrink-0 border-b border-gray-200">Hello</div>
<div className="w-full h-full relative overflow-hidden">
<IssueKanBanViewRoot />
</div>
</div>
</div>
);
};
export default KanBanViewRoot;

View File

@ -0,0 +1,36 @@
import React from "react";
// next imports
import { useRouter } from "next/router";
// components
import { IssuesRoot } from "components/issue-layouts/root";
// mobx store
import { useMobxStore } from "lib/mobx/store-provider";
import { RootStore } from "store/root";
const KanBanViewRoot = () => {
const router = useRouter();
const { workspace_slug, project_slug, cycle_slug } = router.query as {
workspace_slug: string;
project_slug: string;
cycle_slug: string;
};
const store: RootStore = useMobxStore();
const { issueView: issueViewStore } = store;
React.useEffect(() => {
console.log("request init--->");
const init = async () =>
await issueViewStore.getIssuesForCyclesAsync(workspace_slug, project_slug, cycle_slug);
if (workspace_slug && project_slug && cycle_slug) init();
console.log("request completed--->");
}, [workspace_slug, project_slug, cycle_slug, issueViewStore]);
return (
<div className="w-screen min-h-[600px] h-screen">
<IssuesRoot />
</div>
);
};
export default KanBanViewRoot;

View File

@ -0,0 +1,35 @@
import React from "react";
// next imports
import { useRouter } from "next/router";
// components
import { IssuesRoot } from "components/issue-layouts/root";
// mobx store
import { useMobxStore } from "lib/mobx/store-provider";
import { RootStore } from "store/root";
const KanBanViewRoot = () => {
const router = useRouter();
const { workspace_slug, project_slug } = router.query as {
workspace_slug: string;
project_slug: string;
};
const store: RootStore = useMobxStore();
const { issueView: issueViewStore } = store;
React.useEffect(() => {
console.log("request init--->");
const init = async () =>
await issueViewStore.getProjectIssuesAsync(workspace_slug, project_slug);
if (workspace_slug && project_slug) init();
console.log("request completed--->");
}, [workspace_slug, project_slug, issueViewStore]);
return (
<div className="w-screen min-h-[600px] h-screen">
<IssuesRoot />
</div>
);
};
export default KanBanViewRoot;

View File

@ -0,0 +1,36 @@
import React from "react";
// next imports
import { useRouter } from "next/router";
// components
import { IssuesRoot } from "components/issue-layouts/root";
// mobx store
import { useMobxStore } from "lib/mobx/store-provider";
import { RootStore } from "store/root";
const KanBanViewRoot = () => {
const router = useRouter();
const { workspace_slug, project_slug, module_slug } = router.query as {
workspace_slug: string;
project_slug: string;
module_slug: string;
};
const store: RootStore = useMobxStore();
const { issueView: issueViewStore } = store;
React.useEffect(() => {
console.log("request init--->");
const init = async () =>
await issueViewStore.getIssuesForModulesAsync(workspace_slug, project_slug, module_slug);
if (workspace_slug && project_slug && module_slug) init();
console.log("request completed--->");
}, [workspace_slug, project_slug, module_slug, issueViewStore]);
return (
<div className="w-screen min-h-[600px] h-screen">
<IssuesRoot />
</div>
);
};
export default KanBanViewRoot;

View File

@ -0,0 +1,36 @@
import React from "react";
// next imports
import { useRouter } from "next/router";
// components
import { IssuesRoot } from "components/issue-layouts/root";
// mobx store
import { useMobxStore } from "lib/mobx/store-provider";
import { RootStore } from "store/root";
const KanBanViewRoot = () => {
const router = useRouter();
const { workspace_slug, project_slug, view_slug } = router.query as {
workspace_slug: string;
project_slug: string;
view_slug: string;
};
const store: RootStore = useMobxStore();
const { issueView: issueViewStore } = store;
React.useEffect(() => {
console.log("request init--->");
const init = async () =>
await issueViewStore.getIssuesForViewsAsync(workspace_slug, project_slug, view_slug);
if (workspace_slug && project_slug && view_slug) init();
console.log("request completed--->");
}, [workspace_slug, project_slug, view_slug, issueViewStore]);
return (
<div className="w-screen min-h-[600px] h-screen">
<IssuesRoot />
</div>
);
};
export default KanBanViewRoot;

View File

@ -0,0 +1,31 @@
import React from "react";
// next imports
import { useRouter } from "next/router";
// components
import { IssuesRoot } from "components/issue-layouts/root";
// mobx store
import { useMobxStore } from "lib/mobx/store-provider";
import { RootStore } from "store/root";
const KanBanViewRoot = () => {
const router = useRouter();
const { workspace_slug } = router.query as { workspace_slug: string };
const store: RootStore = useMobxStore();
const { issueView: issueViewStore } = store;
React.useEffect(() => {
console.log("request init--->");
const init = async () => await issueViewStore.getMyIssuesAsync(workspace_slug);
if (workspace_slug) init();
console.log("request completed--->");
}, [workspace_slug, issueViewStore]);
return (
<div className="w-screen min-h-[600px] h-screen">
<IssuesRoot />
</div>
);
};
export default KanBanViewRoot;

View File

@ -18,7 +18,7 @@ export interface IIssuesLayout {
kanban: IIssues; kanban: IIssues;
calendar: IIssues; calendar: IIssues;
spreadsheet: IIssues; spreadsheet: IIssues;
gantt: IIssues; gantt_chart: IIssues;
} }
export interface IIssueState { export interface IIssueState {

View File

@ -108,21 +108,21 @@ export const issueFilterVisibilityData: any = {
}, },
}, },
others: { others: {
layout: ["list", "kanban", "calendar", "spreadsheet", "gantt"], layout: ["list", "kanban", "calendar", "spreadsheet", "gantt_chart"],
filters: ["priority", "state", "assignees", "created_by", "labels", "start_date", "due_date"], filters: ["priority", "state", "assignees", "created_by", "labels", "start_date", "due_date"],
display_properties: { display_properties: {
list: true, list: true,
kanban: true, kanban: true,
calendar: true, calendar: true,
spreadsheet: true, spreadsheet: true,
gantt: false, gantt_chart: false,
}, },
display_filters: { display_filters: {
list: ["group_by", "order_by", "issue_type", "sub_issue", "show_empty_groups"], list: ["group_by", "order_by", "issue_type", "sub_issue", "show_empty_groups"],
kanban: ["group_by", "order_by", "issue_type", "sub_issue", "show_empty_groups"], kanban: ["group_by", "order_by", "issue_type", "sub_issue", "show_empty_groups"],
calendar: ["issue_type"], calendar: ["issue_type"],
spreadsheet: ["issue_type"], spreadsheet: ["issue_type"],
gantt: ["order_by", "issue_type", "sub_issue"], gantt_chart: ["order_by", "issue_type", "sub_issue"],
}, },
extra_options: { extra_options: {
list: { list: {
@ -141,7 +141,7 @@ export const issueFilterVisibilityData: any = {
access: false, access: false,
values: [], values: [],
}, },
gantt: { gantt_chart: {
access: true, access: true,
values: ["sub_issue"], values: ["sub_issue"],
}, },

View File

@ -23,7 +23,7 @@ import {
} from "./issue_data"; } from "./issue_data";
export type TIssueViews = "my_issues" | "issues" | "modules" | "views" | "cycles"; export type TIssueViews = "my_issues" | "issues" | "modules" | "views" | "cycles";
export type TIssueLayouts = "list" | "kanban" | "calendar" | "spreadsheet" | "gantt"; export type TIssueLayouts = "list" | "kanban" | "calendar" | "spreadsheet" | "gantt_chart";
export interface IIssueFilter { export interface IIssueFilter {
priority: string[] | undefined; priority: string[] | undefined;
@ -758,7 +758,7 @@ class IssueFilterStore implements IIssueFilterStore {
"type", "type",
"sub_issues", "sub_issues",
]; ];
if (_layout === "gantt") if (_layout === "gantt_chart")
filteredParams = [ filteredParams = [
"priority", "priority",
"state", "state",