@powerhousedao/network-admin 0.0.36 → 0.0.37
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/document-models/index.d.ts.map +1 -1
- package/dist/document-models/index.js +0 -1
- package/dist/document-models/network-profile/gen/document-model.d.ts +2 -2
- package/dist/document-models/network-profile/gen/document-model.d.ts.map +1 -1
- package/dist/document-models/network-profile/gen/index.d.ts +2 -0
- package/dist/document-models/network-profile/gen/index.d.ts.map +1 -1
- package/dist/document-models/network-profile/gen/index.js +1 -0
- package/dist/document-models/network-profile/gen/network-profile-management/actions.js +1 -1
- package/dist/document-models/network-profile/gen/network-profile-management/creators.js +1 -2
- package/dist/document-models/network-profile/gen/network-profile-management/object.d.ts +17 -0
- package/dist/document-models/network-profile/gen/network-profile-management/object.d.ts.map +1 -0
- package/dist/document-models/network-profile/gen/network-profile-management/object.js +37 -0
- package/dist/document-models/network-profile/gen/network-profile-management/operations.js +1 -3
- package/dist/document-models/network-profile/gen/object.d.ts +15 -0
- package/dist/document-models/network-profile/gen/object.d.ts.map +1 -0
- package/dist/document-models/network-profile/gen/object.js +25 -0
- package/dist/document-models/network-profile/gen/ph-factories.d.ts +10 -6
- package/dist/document-models/network-profile/gen/ph-factories.d.ts.map +1 -1
- package/dist/document-models/network-profile/gen/ph-factories.js +4 -1
- package/dist/document-models/network-profile/gen/reducer.d.ts +2 -2
- package/dist/document-models/network-profile/gen/reducer.d.ts.map +1 -1
- package/dist/document-models/network-profile/gen/reducer.js +4 -1
- package/dist/document-models/network-profile/gen/types.d.ts +6 -9
- package/dist/document-models/network-profile/gen/types.d.ts.map +1 -1
- package/dist/document-models/network-profile/gen/types.js +0 -1
- package/dist/document-models/network-profile/gen/utils.d.ts +19 -9
- package/dist/document-models/network-profile/gen/utils.d.ts.map +1 -1
- package/dist/document-models/network-profile/gen/utils.js +34 -26
- package/dist/document-models/network-profile/index.d.ts +4 -10
- package/dist/document-models/network-profile/index.d.ts.map +1 -1
- package/dist/document-models/network-profile/index.js +3 -4
- package/dist/document-models/network-profile/ph-factories.d.ts +27 -0
- package/dist/document-models/network-profile/ph-factories.d.ts.map +1 -0
- package/dist/document-models/network-profile/ph-factories.js +60 -0
- package/dist/document-models/network-profile/src/reducers/network-profile-management.js +11 -11
- package/dist/document-models/network-profile/src/tests/document-model.test.js +1 -1
- package/dist/document-models/network-profile/src/tests/network-profile-management.test.js +0 -1
- package/dist/document-models/payment-terms/gen/clauses/actions.js +1 -1
- package/dist/document-models/payment-terms/gen/clauses/creators.js +1 -2
- package/dist/document-models/payment-terms/gen/clauses/object.d.ts +12 -0
- package/dist/document-models/payment-terms/gen/clauses/object.d.ts.map +1 -0
- package/dist/document-models/payment-terms/gen/clauses/object.js +22 -0
- package/dist/document-models/payment-terms/gen/clauses/operations.js +1 -3
- package/dist/document-models/payment-terms/gen/document-model.d.ts +2 -2
- package/dist/document-models/payment-terms/gen/document-model.d.ts.map +1 -1
- package/dist/document-models/payment-terms/gen/index.d.ts +2 -0
- package/dist/document-models/payment-terms/gen/index.d.ts.map +1 -1
- package/dist/document-models/payment-terms/gen/index.js +1 -0
- package/dist/document-models/payment-terms/gen/milestones/actions.js +1 -1
- package/dist/document-models/payment-terms/gen/milestones/creators.js +1 -2
- package/dist/document-models/payment-terms/gen/milestones/object.d.ts +11 -0
- package/dist/document-models/payment-terms/gen/milestones/object.d.ts.map +1 -0
- package/dist/document-models/payment-terms/gen/milestones/object.js +19 -0
- package/dist/document-models/payment-terms/gen/milestones/operations.js +1 -3
- package/dist/document-models/payment-terms/gen/object.d.ts +19 -0
- package/dist/document-models/payment-terms/gen/object.d.ts.map +1 -0
- package/dist/document-models/payment-terms/gen/object.js +33 -0
- package/dist/document-models/payment-terms/gen/ph-factories.d.ts +10 -6
- package/dist/document-models/payment-terms/gen/ph-factories.d.ts.map +1 -1
- package/dist/document-models/payment-terms/gen/ph-factories.js +4 -1
- package/dist/document-models/payment-terms/gen/reducer.d.ts +2 -2
- package/dist/document-models/payment-terms/gen/reducer.d.ts.map +1 -1
- package/dist/document-models/payment-terms/gen/reducer.js +4 -1
- package/dist/document-models/payment-terms/gen/terms/actions.js +1 -1
- package/dist/document-models/payment-terms/gen/terms/creators.js +1 -2
- package/dist/document-models/payment-terms/gen/terms/object.d.ts +12 -0
- package/dist/document-models/payment-terms/gen/terms/object.d.ts.map +1 -0
- package/dist/document-models/payment-terms/gen/terms/object.js +22 -0
- package/dist/document-models/payment-terms/gen/terms/operations.js +1 -3
- package/dist/document-models/payment-terms/gen/types.d.ts +6 -9
- package/dist/document-models/payment-terms/gen/types.d.ts.map +1 -1
- package/dist/document-models/payment-terms/gen/types.js +0 -1
- package/dist/document-models/payment-terms/gen/utils.d.ts +19 -9
- package/dist/document-models/payment-terms/gen/utils.d.ts.map +1 -1
- package/dist/document-models/payment-terms/gen/utils.js +34 -26
- package/dist/document-models/payment-terms/index.d.ts +4 -10
- package/dist/document-models/payment-terms/index.d.ts.map +1 -1
- package/dist/document-models/payment-terms/index.js +3 -4
- package/dist/document-models/payment-terms/ph-factories.d.ts +27 -0
- package/dist/document-models/payment-terms/ph-factories.d.ts.map +1 -0
- package/dist/document-models/payment-terms/ph-factories.js +62 -0
- package/dist/document-models/payment-terms/src/tests/document-model.test.js +1 -1
- package/dist/document-models/request-for-proposals/gen/contex-document/actions.js +1 -1
- package/dist/document-models/request-for-proposals/gen/contex-document/creators.js +1 -2
- package/dist/document-models/request-for-proposals/gen/contex-document/object.d.ts +8 -0
- package/dist/document-models/request-for-proposals/gen/contex-document/object.d.ts.map +1 -0
- package/dist/document-models/request-for-proposals/gen/contex-document/object.js +10 -0
- package/dist/document-models/request-for-proposals/gen/contex-document/operations.js +1 -3
- package/dist/document-models/request-for-proposals/gen/document-model.d.ts +2 -2
- package/dist/document-models/request-for-proposals/gen/document-model.d.ts.map +1 -1
- package/dist/document-models/request-for-proposals/gen/index.d.ts +2 -0
- package/dist/document-models/request-for-proposals/gen/index.d.ts.map +1 -1
- package/dist/document-models/request-for-proposals/gen/index.js +1 -0
- package/dist/document-models/request-for-proposals/gen/object.d.ts +19 -0
- package/dist/document-models/request-for-proposals/gen/object.d.ts.map +1 -0
- package/dist/document-models/request-for-proposals/gen/object.js +33 -0
- package/dist/document-models/request-for-proposals/gen/ph-factories.d.ts +10 -6
- package/dist/document-models/request-for-proposals/gen/ph-factories.d.ts.map +1 -1
- package/dist/document-models/request-for-proposals/gen/ph-factories.js +7 -4
- package/dist/document-models/request-for-proposals/gen/proposals/actions.js +1 -1
- package/dist/document-models/request-for-proposals/gen/proposals/creators.js +1 -2
- package/dist/document-models/request-for-proposals/gen/proposals/object.d.ts +9 -0
- package/dist/document-models/request-for-proposals/gen/proposals/object.d.ts.map +1 -0
- package/dist/document-models/request-for-proposals/gen/proposals/object.js +13 -0
- package/dist/document-models/request-for-proposals/gen/proposals/operations.js +1 -3
- package/dist/document-models/request-for-proposals/gen/reducer.d.ts +2 -2
- package/dist/document-models/request-for-proposals/gen/reducer.d.ts.map +1 -1
- package/dist/document-models/request-for-proposals/gen/reducer.js +4 -1
- package/dist/document-models/request-for-proposals/gen/rfp-state/actions.js +1 -1
- package/dist/document-models/request-for-proposals/gen/rfp-state/creators.js +1 -2
- package/dist/document-models/request-for-proposals/gen/rfp-state/object.d.ts +7 -0
- package/dist/document-models/request-for-proposals/gen/rfp-state/object.d.ts.map +1 -0
- package/dist/document-models/request-for-proposals/gen/rfp-state/object.js +7 -0
- package/dist/document-models/request-for-proposals/gen/rfp-state/operations.js +1 -3
- package/dist/document-models/request-for-proposals/gen/types.d.ts +6 -9
- package/dist/document-models/request-for-proposals/gen/types.d.ts.map +1 -1
- package/dist/document-models/request-for-proposals/gen/types.js +0 -1
- package/dist/document-models/request-for-proposals/gen/utils.d.ts +19 -9
- package/dist/document-models/request-for-proposals/gen/utils.d.ts.map +1 -1
- package/dist/document-models/request-for-proposals/gen/utils.js +36 -28
- package/dist/document-models/request-for-proposals/index.d.ts +4 -10
- package/dist/document-models/request-for-proposals/index.d.ts.map +1 -1
- package/dist/document-models/request-for-proposals/index.js +3 -4
- package/dist/document-models/request-for-proposals/ph-factories.d.ts +27 -0
- package/dist/document-models/request-for-proposals/ph-factories.d.ts.map +1 -0
- package/dist/document-models/request-for-proposals/ph-factories.js +67 -0
- package/dist/document-models/request-for-proposals/src/tests/contex-document.test.js +0 -1
- package/dist/document-models/request-for-proposals/src/tests/document-model.test.js +1 -1
- package/dist/document-models/request-for-proposals/src/tests/proposals.test.js +0 -1
- package/dist/document-models/request-for-proposals/src/tests/rfp-state.test.js +0 -1
- package/dist/document-models/workstream/gen/document-model.d.ts +2 -2
- package/dist/document-models/workstream/gen/document-model.d.ts.map +1 -1
- package/dist/document-models/workstream/gen/index.d.ts +2 -0
- package/dist/document-models/workstream/gen/index.d.ts.map +1 -1
- package/dist/document-models/workstream/gen/index.js +1 -0
- package/dist/document-models/workstream/gen/object.d.ts +17 -0
- package/dist/document-models/workstream/gen/object.d.ts.map +1 -0
- package/dist/document-models/workstream/gen/object.js +27 -0
- package/dist/document-models/workstream/gen/ph-factories.d.ts +10 -6
- package/dist/document-models/workstream/gen/ph-factories.d.ts.map +1 -1
- package/dist/document-models/workstream/gen/ph-factories.js +4 -1
- package/dist/document-models/workstream/gen/proposals/actions.js +1 -1
- package/dist/document-models/workstream/gen/proposals/creators.js +1 -2
- package/dist/document-models/workstream/gen/proposals/object.d.ts +10 -0
- package/dist/document-models/workstream/gen/proposals/object.d.ts.map +1 -0
- package/dist/document-models/workstream/gen/proposals/object.js +16 -0
- package/dist/document-models/workstream/gen/proposals/operations.js +1 -3
- package/dist/document-models/workstream/gen/reducer.d.ts +2 -2
- package/dist/document-models/workstream/gen/reducer.d.ts.map +1 -1
- package/dist/document-models/workstream/gen/reducer.js +4 -1
- package/dist/document-models/workstream/gen/types.d.ts +6 -9
- package/dist/document-models/workstream/gen/types.d.ts.map +1 -1
- package/dist/document-models/workstream/gen/types.js +0 -1
- package/dist/document-models/workstream/gen/utils.d.ts +19 -9
- package/dist/document-models/workstream/gen/utils.d.ts.map +1 -1
- package/dist/document-models/workstream/gen/utils.js +34 -26
- package/dist/document-models/workstream/gen/workstream/actions.js +1 -1
- package/dist/document-models/workstream/gen/workstream/creators.js +1 -2
- package/dist/document-models/workstream/gen/workstream/object.d.ts +11 -0
- package/dist/document-models/workstream/gen/workstream/object.d.ts.map +1 -0
- package/dist/document-models/workstream/gen/workstream/object.js +19 -0
- package/dist/document-models/workstream/gen/workstream/operations.js +1 -3
- package/dist/document-models/workstream/index.d.ts +4 -10
- package/dist/document-models/workstream/index.d.ts.map +1 -1
- package/dist/document-models/workstream/index.js +3 -4
- package/dist/document-models/workstream/ph-factories.d.ts +27 -0
- package/dist/document-models/workstream/ph-factories.d.ts.map +1 -0
- package/dist/document-models/workstream/ph-factories.js +59 -0
- package/dist/document-models/workstream/src/tests/document-model.test.js +1 -1
- package/dist/document-models/workstream/src/tests/proposals-reducers.test.js +0 -2
- package/dist/document-models/workstream/src/tests/workstream-reducers.test.js +0 -2
- package/dist/editors/index.d.ts +1 -1
- package/dist/editors/index.d.ts.map +1 -1
- package/dist/editors/index.js +1 -2
- package/dist/editors/network-admin/components/DriveExplorer.d.ts +4 -3
- package/dist/editors/network-admin/components/DriveExplorer.d.ts.map +1 -1
- package/dist/editors/network-admin/components/DriveExplorer.js +43 -34
- package/dist/editors/network-admin/components/icons/PaymentIcon.d.ts +1 -1
- package/dist/editors/network-admin/components/icons/PaymentIcon.d.ts.map +1 -1
- package/dist/editors/network-admin/components/icons/RfpIcon.d.ts +1 -1
- package/dist/editors/network-admin/components/icons/RfpIcon.d.ts.map +1 -1
- package/dist/editors/network-admin/components/icons/SowIcon.d.ts +1 -1
- package/dist/editors/network-admin/components/icons/SowIcon.d.ts.map +1 -1
- package/dist/editors/network-admin/components/icons/WorkstreamIcon.d.ts +1 -1
- package/dist/editors/network-admin/components/icons/WorkstreamIcon.d.ts.map +1 -1
- package/dist/editors/network-admin/editor.d.ts +3 -2
- package/dist/editors/network-admin/editor.d.ts.map +1 -1
- package/dist/editors/network-admin/editor.js +2 -7
- package/dist/editors/network-admin/index.d.ts +2 -2
- package/dist/editors/network-admin/index.d.ts.map +1 -1
- package/dist/editors/network-admin/index.js +14 -2
- package/dist/editors/network-admin/utils/withDropZone.d.ts +4 -0
- package/dist/editors/network-admin/utils/withDropZone.d.ts.map +1 -0
- package/dist/editors/network-admin/utils/withDropZone.js +19 -0
- package/dist/editors/network-profile/editor.d.ts.map +1 -1
- package/dist/editors/network-profile/editor.js +29 -37
- package/dist/editors/network-profile/index.d.ts.map +1 -1
- package/dist/editors/network-profile/index.js +3 -1
- package/dist/editors/payment-terms/basic-terms-tab.d.ts +1 -1
- package/dist/editors/payment-terms/basic-terms-tab.d.ts.map +1 -1
- package/dist/editors/payment-terms/basic-terms-tab.js +5 -6
- package/dist/editors/payment-terms/clauses-tab.d.ts +2 -2
- package/dist/editors/payment-terms/clauses-tab.d.ts.map +1 -1
- package/dist/editors/payment-terms/clauses-tab.js +26 -31
- package/dist/editors/payment-terms/cost-materials-tab.d.ts +1 -1
- package/dist/editors/payment-terms/cost-materials-tab.d.ts.map +1 -1
- package/dist/editors/payment-terms/cost-materials-tab.js +4 -5
- package/dist/editors/payment-terms/editor.d.ts.map +1 -1
- package/dist/editors/payment-terms/editor.js +2 -10
- package/dist/editors/payment-terms/escrow-tab.d.ts +1 -1
- package/dist/editors/payment-terms/escrow-tab.d.ts.map +1 -1
- package/dist/editors/payment-terms/escrow-tab.js +3 -4
- package/dist/editors/payment-terms/evaluation-tab.d.ts +1 -1
- package/dist/editors/payment-terms/evaluation-tab.d.ts.map +1 -1
- package/dist/editors/payment-terms/evaluation-tab.js +4 -5
- package/dist/editors/payment-terms/index.d.ts.map +1 -1
- package/dist/editors/payment-terms/index.js +3 -1
- package/dist/editors/payment-terms/milestones-tab.d.ts +1 -1
- package/dist/editors/payment-terms/milestones-tab.d.ts.map +1 -1
- package/dist/editors/payment-terms/milestones-tab.js +6 -8
- package/dist/editors/payment-terms/retainer-tab.d.ts +1 -1
- package/dist/editors/payment-terms/retainer-tab.d.ts.map +1 -1
- package/dist/editors/payment-terms/retainer-tab.js +4 -5
- package/dist/editors/request-for-proposals/editor.d.ts.map +1 -1
- package/dist/editors/request-for-proposals/editor.js +48 -58
- package/dist/editors/request-for-proposals/index.d.ts.map +1 -1
- package/dist/editors/request-for-proposals/index.js +3 -1
- package/dist/editors/workstream/editor.d.ts.map +1 -1
- package/dist/editors/workstream/editor.js +290 -314
- package/dist/editors/workstream/index.d.ts.map +1 -1
- package/dist/editors/workstream/index.js +3 -1
- package/dist/index.d.ts +3 -3
- package/dist/index.d.ts.map +1 -1
- package/dist/powerhouse.manifest.json +83 -9
- package/dist/processors/factory.d.ts +1 -1
- package/dist/processors/factory.d.ts.map +1 -1
- package/dist/processors/factory.js +0 -2
- package/dist/processors/index.js +0 -1
- package/dist/processors/workstreams/factory.d.ts +1 -1
- package/dist/processors/workstreams/factory.d.ts.map +1 -1
- package/dist/processors/workstreams/factory.js +0 -3
- package/dist/processors/workstreams/index.d.ts +2 -2
- package/dist/processors/workstreams/index.d.ts.map +1 -1
- package/dist/processors/workstreams/index.js +2 -6
- package/dist/processors/workstreams/migrations.d.ts +1 -1
- package/dist/processors/workstreams/migrations.d.ts.map +1 -1
- package/dist/processors/workstreams/migrations.js +0 -1
- package/dist/scripts/sow-mirror/mirror_sow_state.js +4 -4
- package/dist/style.css +18004 -1867
- package/dist/subgraphs/index.js +0 -1
- package/dist/subgraphs/network-profile/index.d.ts +2 -2
- package/dist/subgraphs/network-profile/index.d.ts.map +1 -1
- package/dist/subgraphs/network-profile/index.js +2 -2
- package/dist/subgraphs/network-profile/resolvers.d.ts +2 -2
- package/dist/subgraphs/network-profile/resolvers.d.ts.map +1 -1
- package/dist/subgraphs/network-profile/resolvers.js +0 -1
- package/dist/subgraphs/networks/index.d.ts +2 -2
- package/dist/subgraphs/networks/index.d.ts.map +1 -1
- package/dist/subgraphs/networks/index.js +2 -2
- package/dist/subgraphs/networks/resolvers.d.ts +2 -2
- package/dist/subgraphs/networks/resolvers.d.ts.map +1 -1
- package/dist/subgraphs/networks/resolvers.js +0 -1
- package/dist/subgraphs/payment-terms/index.d.ts +2 -2
- package/dist/subgraphs/payment-terms/index.d.ts.map +1 -1
- package/dist/subgraphs/payment-terms/index.js +2 -2
- package/dist/subgraphs/payment-terms/resolvers.d.ts +2 -2
- package/dist/subgraphs/payment-terms/resolvers.d.ts.map +1 -1
- package/dist/subgraphs/payment-terms/resolvers.js +0 -1
- package/dist/subgraphs/request-for-proposals/index.d.ts +2 -2
- package/dist/subgraphs/request-for-proposals/index.d.ts.map +1 -1
- package/dist/subgraphs/request-for-proposals/index.js +2 -2
- package/dist/subgraphs/request-for-proposals/resolvers.d.ts +2 -2
- package/dist/subgraphs/request-for-proposals/resolvers.d.ts.map +1 -1
- package/dist/subgraphs/request-for-proposals/resolvers.js +0 -1
- package/dist/subgraphs/workstream/index.d.ts +2 -2
- package/dist/subgraphs/workstream/index.d.ts.map +1 -1
- package/dist/subgraphs/workstream/index.js +2 -2
- package/dist/subgraphs/workstream/resolvers.d.ts +2 -2
- package/dist/subgraphs/workstream/resolvers.d.ts.map +1 -1
- package/dist/subgraphs/workstream/resolvers.js +0 -1
- package/dist/subgraphs/workstreams/index.d.ts +2 -2
- package/dist/subgraphs/workstreams/index.d.ts.map +1 -1
- package/dist/subgraphs/workstreams/index.js +2 -2
- package/dist/subgraphs/workstreams/resolvers.d.ts +2 -2
- package/dist/subgraphs/workstreams/resolvers.d.ts.map +1 -1
- package/dist/subgraphs/workstreams/resolvers.js +0 -3
- package/package.json +37 -56
- package/dist/editors/network-admin/components/CreateDocument.d.ts +0 -6
- package/dist/editors/network-admin/components/CreateDocument.d.ts.map +0 -1
- package/dist/editors/network-admin/components/CreateDocument.js +0 -22
- package/dist/editors/network-admin/components/FolderTree.d.ts +0 -6
- package/dist/editors/network-admin/components/FolderTree.d.ts.map +0 -1
- package/dist/editors/network-admin/components/FolderTree.js +0 -65
- package/dist/editors/network-admin/config.d.ts +0 -3
- package/dist/editors/network-admin/config.d.ts.map +0 -1
- package/dist/editors/network-admin/config.js +0 -11
- package/dist/editors/workstream/project-management-import.d.ts +0 -3
- package/dist/editors/workstream/project-management-import.d.ts.map +0 -1
- package/dist/editors/workstream/project-management-import.js +0 -5
- package/dist/vite.config.d.ts +0 -3
- package/dist/vite.config.d.ts.map +0 -1
- package/dist/vite.config.js +0 -11
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import type { PaymentTermsState } from "../../document-models/payment-terms/gen/types.js";
|
|
2
2
|
import type { PaymentTermsAction } from "../../document-models/payment-terms/gen/actions.js";
|
|
3
|
-
import {
|
|
3
|
+
import { actions as paymentTermsActions } from "../../document-models/payment-terms/index.js";
|
|
4
4
|
export interface BasicTermsTabProps {
|
|
5
5
|
state: PaymentTermsState;
|
|
6
6
|
dispatch: (action: PaymentTermsAction) => void;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"basic-terms-tab.d.ts","sourceRoot":"","sources":["../../../editors/payment-terms/basic-terms-tab.tsx"],"names":[],"mappings":"AAGA,OAAO,KAAK,EACV,iBAAiB,EAIlB,MAAM,kDAAkD,CAAC;AAC1D,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,oDAAoD,CAAC;AAC7F,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"basic-terms-tab.d.ts","sourceRoot":"","sources":["../../../editors/payment-terms/basic-terms-tab.tsx"],"names":[],"mappings":"AAGA,OAAO,KAAK,EACV,iBAAiB,EAIlB,MAAM,kDAAkD,CAAC;AAC1D,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,oDAAoD,CAAC;AAC7F,OAAO,EAAE,OAAO,IAAI,mBAAmB,EAAE,MAAM,8CAA8C,CAAC;AAE9F,MAAM,WAAW,kBAAkB;IACjC,KAAK,EAAE,iBAAiB,CAAC;IACzB,QAAQ,EAAE,CAAC,MAAM,EAAE,kBAAkB,KAAK,IAAI,CAAC;IAC/C,OAAO,EAAE,OAAO,mBAAmB,CAAC;CACrC;AAED,wBAAgB,aAAa,CAAC,EAC5B,KAAK,EACL,QAAQ,EACR,OAAO,GACR,EAAE,kBAAkB,2CA4SpB"}
|
|
@@ -1,8 +1,7 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
-
import { useState, useCallback
|
|
3
|
-
import { toast } from "@powerhousedao/design-system";
|
|
4
|
-
import { Select, TextInput
|
|
5
|
-
import {} from "../../document-models/payment-terms/index.js";
|
|
2
|
+
import { useState, useCallback } from "react";
|
|
3
|
+
import { toast, Button } from "@powerhousedao/design-system";
|
|
4
|
+
import { Select, TextInput } from "@powerhousedao/document-engineering";
|
|
6
5
|
export function BasicTermsTab({ state, dispatch, actions, }) {
|
|
7
6
|
const [isEditing, setIsEditing] = useState(false);
|
|
8
7
|
const [formData, setFormData] = useState({
|
|
@@ -66,7 +65,7 @@ export function BasicTermsTab({ state, dispatch, actions, }) {
|
|
|
66
65
|
setIsEditing(false);
|
|
67
66
|
}, [state]);
|
|
68
67
|
if (!isEditing) {
|
|
69
|
-
return (_jsxs("div", { className: "space-y-6", children: [_jsxs("div", { className: "flex justify-between items-center mb-4", children: [_jsx("h2", { className: "text-xl font-semibold", children: "Basic Information" }), _jsx(Button, { onClick: () => setIsEditing(true), color: "light", size: "
|
|
68
|
+
return (_jsxs("div", { className: "space-y-6", children: [_jsxs("div", { className: "flex justify-between items-center mb-4", children: [_jsx("h2", { className: "text-xl font-semibold", children: "Basic Information" }), _jsx(Button, { onClick: () => setIsEditing(true), color: "light", size: "small", className: "cursor-pointer hover:bg-blue-600 hover:text-white", children: "Edit Terms" })] }), _jsxs("div", { className: "grid grid-cols-2 gap-6", children: [_jsxs("div", { children: [_jsx("label", { className: "block text-sm font-medium text-gray-700 mb-1", children: "Proposer" }), _jsx("p", { className: "text-lg", children: state.proposer || "Not set" })] }), _jsxs("div", { children: [_jsx("label", { className: "block text-sm font-medium text-gray-700 mb-1", children: "Payer" }), _jsx("p", { className: "text-lg", children: state.payer || "Not set" })] }), _jsxs("div", { children: [_jsx("label", { className: "block text-sm font-medium text-gray-700 mb-1", children: "Currency" }), _jsx("p", { className: "text-lg", children: state.currency })] }), _jsxs("div", { children: [_jsx("label", { className: "block text-sm font-medium text-gray-700 mb-1", children: "Payment Model" }), _jsx("p", { className: "text-lg", children: state.paymentModel.replace(/_/g, " ") })] }), _jsxs("div", { children: [_jsx("label", { className: "block text-sm font-medium text-gray-700 mb-1", children: "Total Amount" }), _jsx("p", { className: "text-lg", children: state.totalAmount
|
|
70
69
|
? `${state.totalAmount.value} ${state.totalAmount.unit}`
|
|
71
70
|
: "Not set" })] }), _jsxs("div", { children: [_jsx("label", { className: "block text-sm font-medium text-gray-700 mb-1", children: "Status" }), _jsx("p", { className: "text-lg", children: state.status })] }), _jsxs("div", { children: [_jsx("label", { className: "block text-sm font-medium text-gray-700 mb-1", children: "Escrow" }), _jsx("p", { className: "text-lg", children: state.escrowDetails && state.escrowDetails.releaseConditions
|
|
72
71
|
? "Enabled"
|
|
@@ -85,5 +84,5 @@ export function BasicTermsTab({ state, dispatch, actions, }) {
|
|
|
85
84
|
{ value: "SUBMITTED", label: "Submitted" },
|
|
86
85
|
{ value: "ACCEPTED", label: "Accepted" },
|
|
87
86
|
{ value: "CANCELLED", label: "Cancelled" },
|
|
88
|
-
], placeholder: "Select status", required: true })] }), _jsx("div", { className: "col-span-2", children: _jsxs("div", { className: "flex items-center", children: [_jsx("input", { type: "checkbox", id: "useEscrow", checked: formData.useEscrow, onChange: (e) => setFormData({ ...formData, useEscrow: e.target.checked }), className: "mr-2 h-4 w-4 text-blue-600 focus:ring-blue-500 border-gray-300 rounded" }), _jsx("label", { htmlFor: "useEscrow", className: "text-sm font-medium text-gray-700", children: "Use Escrow" })] }) })] }), _jsxs("div", { className: "flex gap-3", children: [_jsx(Button, { type: "submit", color: "light", size: "
|
|
87
|
+
], placeholder: "Select status", required: true })] }), _jsx("div", { className: "col-span-2", children: _jsxs("div", { className: "flex items-center", children: [_jsx("input", { type: "checkbox", id: "useEscrow", checked: formData.useEscrow, onChange: (e) => setFormData({ ...formData, useEscrow: e.target.checked }), className: "mr-2 h-4 w-4 text-blue-600 focus:ring-blue-500 border-gray-300 rounded" }), _jsx("label", { htmlFor: "useEscrow", className: "text-sm font-medium text-gray-700", children: "Use Escrow" })] }) })] }), _jsxs("div", { className: "flex gap-3", children: [_jsx(Button, { type: "submit", color: "light", size: "small", className: "cursor-pointer hover:bg-blue-600 hover:text-white", children: "Save Terms" }), _jsx(Button, { type: "button", onClick: handleCancel, color: "light", size: "small", className: "cursor-pointer hover:bg-gray-600 hover:text-white", children: "Cancel" })] })] }));
|
|
89
88
|
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import type { BonusClause, PenaltyClause } from "../../document-models/payment-terms/gen/types.js";
|
|
2
2
|
import type { PaymentTermsAction } from "../../document-models/payment-terms/gen/actions.js";
|
|
3
|
-
import {
|
|
3
|
+
import { actions as paymentTermsActions } from "../../document-models/payment-terms/index.js";
|
|
4
4
|
export interface ClausesTabProps {
|
|
5
5
|
bonusClauses: BonusClause[];
|
|
6
6
|
penaltyClauses: PenaltyClause[];
|
|
@@ -8,5 +8,5 @@ export interface ClausesTabProps {
|
|
|
8
8
|
actions: typeof paymentTermsActions;
|
|
9
9
|
currency: string;
|
|
10
10
|
}
|
|
11
|
-
export declare function ClausesTab({ bonusClauses, penaltyClauses, dispatch, actions, currency
|
|
11
|
+
export declare function ClausesTab({ bonusClauses, penaltyClauses, dispatch, actions, currency }: ClausesTabProps): import("react/jsx-runtime").JSX.Element;
|
|
12
12
|
//# sourceMappingURL=clauses-tab.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"clauses-tab.d.ts","sourceRoot":"","sources":["../../../editors/payment-terms/clauses-tab.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"clauses-tab.d.ts","sourceRoot":"","sources":["../../../editors/payment-terms/clauses-tab.tsx"],"names":[],"mappings":"AAKA,OAAO,KAAK,EACV,WAAW,EACX,aAAa,EACd,MAAM,kDAAkD,CAAC;AAC1D,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,oDAAoD,CAAC;AAC7F,OAAO,EAAE,OAAO,IAAI,mBAAmB,EAAE,MAAM,8CAA8C,CAAC;AAE9F,MAAM,WAAW,eAAe;IAC9B,YAAY,EAAE,WAAW,EAAE,CAAC;IAC5B,cAAc,EAAE,aAAa,EAAE,CAAC;IAChC,QAAQ,EAAE,CAAC,MAAM,EAAE,kBAAkB,KAAK,IAAI,CAAC;IAC/C,OAAO,EAAE,OAAO,mBAAmB,CAAC;IACpC,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED,wBAAgB,UAAU,CAAC,EAAE,YAAY,EAAE,cAAc,EAAE,QAAQ,EAAE,OAAO,EAAE,QAAgB,EAAE,EAAE,eAAe,2CAoVhH"}
|
|
@@ -1,16 +1,15 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
2
|
import { useState, useCallback, useMemo } from "react";
|
|
3
|
-
import { ObjectSetTable, TextInput, Textarea
|
|
4
|
-
import { Icon, toast } from "@powerhousedao/design-system";
|
|
5
|
-
import { generateId } from "document-model
|
|
6
|
-
|
|
7
|
-
export function ClausesTab({ bonusClauses, penaltyClauses, dispatch, actions, currency = "USD", }) {
|
|
3
|
+
import { ObjectSetTable, TextInput, Textarea } from "@powerhousedao/document-engineering";
|
|
4
|
+
import { Button, Icon, toast } from "@powerhousedao/design-system";
|
|
5
|
+
import { generateId } from "document-model";
|
|
6
|
+
export function ClausesTab({ bonusClauses, penaltyClauses, dispatch, actions, currency = "USD" }) {
|
|
8
7
|
const [activeSubTab, setActiveSubTab] = useState("bonus");
|
|
9
8
|
const [isAddingNew, setIsAddingNew] = useState(false);
|
|
10
9
|
const [newClause, setNewClause] = useState({
|
|
11
10
|
condition: "",
|
|
12
11
|
amount: "",
|
|
13
|
-
comment: ""
|
|
12
|
+
comment: ""
|
|
14
13
|
});
|
|
15
14
|
const bonusColumns = useMemo(() => [
|
|
16
15
|
{
|
|
@@ -21,7 +20,7 @@ export function ClausesTab({ bonusClauses, penaltyClauses, dispatch, actions, cu
|
|
|
21
20
|
onSave: (newValue, context) => {
|
|
22
21
|
dispatch(actions.updateBonusClause({
|
|
23
22
|
id: context.row.id,
|
|
24
|
-
condition: newValue
|
|
23
|
+
condition: newValue
|
|
25
24
|
}));
|
|
26
25
|
toast("Bonus clause condition updated", {
|
|
27
26
|
type: "success",
|
|
@@ -47,7 +46,7 @@ export function ClausesTab({ bonusClauses, penaltyClauses, dispatch, actions, cu
|
|
|
47
46
|
}
|
|
48
47
|
dispatch(actions.updateBonusClause({
|
|
49
48
|
id: context.row.id,
|
|
50
|
-
bonusAmount: { value: amount, unit: currency }
|
|
49
|
+
bonusAmount: { value: amount, unit: currency }
|
|
51
50
|
}));
|
|
52
51
|
toast("Bonus amount updated", {
|
|
53
52
|
type: "success",
|
|
@@ -64,14 +63,14 @@ export function ClausesTab({ bonusClauses, penaltyClauses, dispatch, actions, cu
|
|
|
64
63
|
onSave: (newValue, context) => {
|
|
65
64
|
dispatch(actions.updateBonusClause({
|
|
66
65
|
id: context.row.id,
|
|
67
|
-
comment: newValue || undefined
|
|
66
|
+
comment: newValue || undefined
|
|
68
67
|
}));
|
|
69
68
|
toast("Bonus clause comment updated", {
|
|
70
69
|
type: "success",
|
|
71
70
|
});
|
|
72
71
|
return true;
|
|
73
72
|
},
|
|
74
|
-
}
|
|
73
|
+
}
|
|
75
74
|
], [actions, currency, dispatch]);
|
|
76
75
|
const penaltyColumns = useMemo(() => [
|
|
77
76
|
{
|
|
@@ -82,7 +81,7 @@ export function ClausesTab({ bonusClauses, penaltyClauses, dispatch, actions, cu
|
|
|
82
81
|
onSave: (newValue, context) => {
|
|
83
82
|
dispatch(actions.updatePenaltyClause({
|
|
84
83
|
id: context.row.id,
|
|
85
|
-
condition: newValue
|
|
84
|
+
condition: newValue
|
|
86
85
|
}));
|
|
87
86
|
toast("Penalty clause condition updated", {
|
|
88
87
|
type: "success",
|
|
@@ -108,7 +107,7 @@ export function ClausesTab({ bonusClauses, penaltyClauses, dispatch, actions, cu
|
|
|
108
107
|
}
|
|
109
108
|
dispatch(actions.updatePenaltyClause({
|
|
110
109
|
id: context.row.id,
|
|
111
|
-
deductionAmount: { value: amount, unit: currency }
|
|
110
|
+
deductionAmount: { value: amount, unit: currency }
|
|
112
111
|
}));
|
|
113
112
|
toast("Deduction amount updated", {
|
|
114
113
|
type: "success",
|
|
@@ -125,25 +124,25 @@ export function ClausesTab({ bonusClauses, penaltyClauses, dispatch, actions, cu
|
|
|
125
124
|
onSave: (newValue, context) => {
|
|
126
125
|
dispatch(actions.updatePenaltyClause({
|
|
127
126
|
id: context.row.id,
|
|
128
|
-
comment: newValue || undefined
|
|
127
|
+
comment: newValue || undefined
|
|
129
128
|
}));
|
|
130
129
|
toast("Penalty clause comment updated", {
|
|
131
130
|
type: "success",
|
|
132
131
|
});
|
|
133
132
|
return true;
|
|
134
133
|
},
|
|
135
|
-
}
|
|
134
|
+
}
|
|
136
135
|
], [actions, currency, dispatch]);
|
|
137
136
|
const handleAddClause = useCallback((e) => {
|
|
138
137
|
e.preventDefault();
|
|
139
138
|
if (!newClause.condition.trim()) {
|
|
140
|
-
toast(
|
|
139
|
+
toast('Condition is required', {
|
|
141
140
|
type: "error",
|
|
142
141
|
});
|
|
143
142
|
return;
|
|
144
143
|
}
|
|
145
144
|
if (!newClause.amount || isNaN(parseFloat(newClause.amount))) {
|
|
146
|
-
toast(
|
|
145
|
+
toast('Valid amount is required', {
|
|
147
146
|
type: "error",
|
|
148
147
|
});
|
|
149
148
|
return;
|
|
@@ -154,9 +153,9 @@ export function ClausesTab({ bonusClauses, penaltyClauses, dispatch, actions, cu
|
|
|
154
153
|
condition: newClause.condition,
|
|
155
154
|
bonusAmount: {
|
|
156
155
|
value: parseFloat(newClause.amount),
|
|
157
|
-
unit: currency
|
|
156
|
+
unit: currency
|
|
158
157
|
},
|
|
159
|
-
comment: newClause.comment || undefined
|
|
158
|
+
comment: newClause.comment || undefined
|
|
160
159
|
}));
|
|
161
160
|
toast("Bonus clause added successfully", {
|
|
162
161
|
type: "success",
|
|
@@ -168,9 +167,9 @@ export function ClausesTab({ bonusClauses, penaltyClauses, dispatch, actions, cu
|
|
|
168
167
|
condition: newClause.condition,
|
|
169
168
|
deductionAmount: {
|
|
170
169
|
value: parseFloat(newClause.amount),
|
|
171
|
-
unit: currency
|
|
170
|
+
unit: currency
|
|
172
171
|
},
|
|
173
|
-
comment: newClause.comment || undefined
|
|
172
|
+
comment: newClause.comment || undefined
|
|
174
173
|
}));
|
|
175
174
|
toast("Penalty clause added successfully", {
|
|
176
175
|
type: "success",
|
|
@@ -179,33 +178,29 @@ export function ClausesTab({ bonusClauses, penaltyClauses, dispatch, actions, cu
|
|
|
179
178
|
setNewClause({
|
|
180
179
|
condition: "",
|
|
181
180
|
amount: "",
|
|
182
|
-
comment: ""
|
|
181
|
+
comment: ""
|
|
183
182
|
});
|
|
184
183
|
setIsAddingNew(false);
|
|
185
184
|
}, [newClause, activeSubTab, dispatch, actions, currency]);
|
|
186
185
|
const currentClauses = activeSubTab === "bonus" ? bonusClauses : penaltyClauses;
|
|
187
|
-
return (_jsxs("div", { className: "space-y-6", children: [_jsxs("div", { className: "flex justify-between items-center", children: [_jsxs("div", { children: [_jsx("h2", { className: "text-xl font-semibold dark:text-white", children: "Bonus & Penalty Clauses" }), _jsxs("p", { className: "text-sm text-gray-600 dark:text-gray-300 mt-1", children: [bonusClauses.length, " bonus clause(s), ", penaltyClauses.length, "
|
|
186
|
+
return (_jsxs("div", { className: "space-y-6", children: [_jsxs("div", { className: "flex justify-between items-center", children: [_jsxs("div", { children: [_jsx("h2", { className: "text-xl font-semibold dark:text-white", children: "Bonus & Penalty Clauses" }), _jsxs("p", { className: "text-sm text-gray-600 dark:text-gray-300 mt-1", children: [bonusClauses.length, " bonus clause(s), ", penaltyClauses.length, " penalty clause(s)"] })] }), _jsxs(Button, { onClick: () => setIsAddingNew(!isAddingNew), color: "light", size: "small", className: "cursor-pointer hover:bg-blue-600 hover:text-white", children: [_jsx(Icon, { name: "Plus", size: 16, className: "mr-2" }), "Add ", activeSubTab === "bonus" ? "Bonus" : "Penalty", " Clause"] })] }), _jsxs("div", { className: "flex space-x-1 border-b border-gray-200 dark:border-gray-600", children: [_jsxs("button", { onClick: () => setActiveSubTab("bonus"), className: `px-4 py-2 text-sm font-medium rounded-t-lg ${activeSubTab === "bonus"
|
|
188
187
|
? "bg-blue-50 dark:bg-blue-900 text-blue-700 dark:text-blue-300 border-b-2 border-blue-700 dark:border-blue-300"
|
|
189
188
|
: "text-gray-500 dark:text-gray-400 hover:text-gray-700 dark:hover:text-gray-200"}`, children: ["Bonus Clauses (", bonusClauses.length, ")"] }), _jsxs("button", { onClick: () => setActiveSubTab("penalty"), className: `px-4 py-2 text-sm font-medium rounded-t-lg ${activeSubTab === "penalty"
|
|
190
189
|
? "bg-red-50 dark:bg-red-900 text-red-700 dark:text-red-300 border-b-2 border-red-700 dark:border-red-300"
|
|
191
|
-
: "text-gray-500 dark:text-gray-400 hover:text-gray-700 dark:hover:text-gray-200"}`, children: ["Penalty Clauses (", penaltyClauses.length, ")"] })] }), isAddingNew && (_jsxs("div", { className: "bg-gray-50 dark:bg-gray-700 p-4 rounded-lg border dark:border-gray-600", children: [_jsxs("h3", { className: "text-lg font-medium mb-4 dark:text-white", children: ["Add New ", activeSubTab === "bonus" ? "Bonus" : "Penalty", " Clause"] }), _jsxs("form", { onSubmit: handleAddClause, className: "space-y-4", children: [_jsx(TextInput, { label: "Condition *", value: newClause.condition, onChange: (e) => setNewClause({ ...newClause, condition: e.target.value }), className: "w-full", required: true }), _jsx(TextInput, { label: `${activeSubTab === "bonus" ? "Bonus" : "Deduction"} Amount (${currency}) *`, type: "number", value: newClause.amount, onChange: (e) => setNewClause({ ...newClause, amount: e.target.value }), className: "w-full", placeholder: "0.00", step: "0.01", required: true }), _jsx(Textarea, { label: "Comment", value: newClause.comment, onChange: (e) => setNewClause({ ...newClause, comment: e.target.value }), className: "w-full", rows: 3, placeholder: "Optional comment or additional details..." }), _jsxs("div", { className: "flex gap-3", children: [_jsxs(Button, { type: "submit", color: "light", size: "
|
|
190
|
+
: "text-gray-500 dark:text-gray-400 hover:text-gray-700 dark:hover:text-gray-200"}`, children: ["Penalty Clauses (", penaltyClauses.length, ")"] })] }), isAddingNew && (_jsxs("div", { className: "bg-gray-50 dark:bg-gray-700 p-4 rounded-lg border dark:border-gray-600", children: [_jsxs("h3", { className: "text-lg font-medium mb-4 dark:text-white", children: ["Add New ", activeSubTab === "bonus" ? "Bonus" : "Penalty", " Clause"] }), _jsxs("form", { onSubmit: handleAddClause, className: "space-y-4", children: [_jsx(TextInput, { label: "Condition *", value: newClause.condition, onChange: (e) => setNewClause({ ...newClause, condition: e.target.value }), className: "w-full", required: true }), _jsx(TextInput, { label: `${activeSubTab === "bonus" ? "Bonus" : "Deduction"} Amount (${currency}) *`, type: "number", value: newClause.amount, onChange: (e) => setNewClause({ ...newClause, amount: e.target.value }), className: "w-full", placeholder: "0.00", step: "0.01", required: true }), _jsx(Textarea, { label: "Comment", value: newClause.comment, onChange: (e) => setNewClause({ ...newClause, comment: e.target.value }), className: "w-full", rows: 3, placeholder: "Optional comment or additional details..." }), _jsxs("div", { className: "flex gap-3", children: [_jsxs(Button, { type: "submit", color: "light", size: "small", className: "cursor-pointer hover:bg-blue-600 hover:text-white", children: ["Add ", activeSubTab === "bonus" ? "Bonus" : "Penalty", " Clause"] }), _jsx(Button, { type: "button", onClick: () => {
|
|
192
191
|
setIsAddingNew(false);
|
|
193
192
|
setNewClause({
|
|
194
193
|
condition: "",
|
|
195
194
|
amount: "",
|
|
196
|
-
comment: ""
|
|
195
|
+
comment: ""
|
|
197
196
|
});
|
|
198
|
-
}, color: "light", size: "
|
|
199
|
-
dispatch(actions.deleteBonusClause({
|
|
200
|
-
id: row.id,
|
|
201
|
-
}));
|
|
197
|
+
}, color: "light", size: "small", className: "cursor-pointer hover:bg-gray-600 hover:text-white", children: "Cancel" })] })] })] })), currentClauses.length > 0 ? (activeSubTab === "bonus" ? (_jsx(ObjectSetTable, { data: bonusClauses, columns: bonusColumns, onAdd: () => setIsAddingNew(true), onDelete: (row) => {
|
|
198
|
+
dispatch(actions.deleteBonusClause({ id: row.id }));
|
|
202
199
|
toast("Bonus clause deleted", {
|
|
203
200
|
type: "success",
|
|
204
201
|
});
|
|
205
202
|
} })) : (_jsx(ObjectSetTable, { data: penaltyClauses, columns: penaltyColumns, onAdd: () => setIsAddingNew(true), onDelete: (row) => {
|
|
206
|
-
dispatch(actions.deletePenaltyClause({
|
|
207
|
-
id: row.id,
|
|
208
|
-
}));
|
|
203
|
+
dispatch(actions.deletePenaltyClause({ id: row.id }));
|
|
209
204
|
toast("Penalty clause deleted", {
|
|
210
205
|
type: "success",
|
|
211
206
|
});
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import type { PaymentTermsState } from "../../document-models/payment-terms/gen/schema/types.js";
|
|
2
2
|
import type { PaymentTermsAction } from "../../document-models/payment-terms/gen/actions.js";
|
|
3
|
-
import {
|
|
3
|
+
import { actions as paymentTermsActions } from "../../document-models/payment-terms/index.js";
|
|
4
4
|
export interface CostMaterialsTabProps {
|
|
5
5
|
state: PaymentTermsState;
|
|
6
6
|
dispatch: (action: PaymentTermsAction) => void;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cost-materials-tab.d.ts","sourceRoot":"","sources":["../../../editors/payment-terms/cost-materials-tab.tsx"],"names":[],"mappings":"AAGA,OAAO,KAAK,EACV,iBAAiB,EAElB,MAAM,yDAAyD,CAAC;AACjE,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,oDAAoD,CAAC;AAC7F,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"cost-materials-tab.d.ts","sourceRoot":"","sources":["../../../editors/payment-terms/cost-materials-tab.tsx"],"names":[],"mappings":"AAGA,OAAO,KAAK,EACV,iBAAiB,EAElB,MAAM,yDAAyD,CAAC;AACjE,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,oDAAoD,CAAC;AAC7F,OAAO,EAAE,OAAO,IAAI,mBAAmB,EAAE,MAAM,8CAA8C,CAAC;AAE9F,MAAM,WAAW,qBAAqB;IACpC,KAAK,EAAE,iBAAiB,CAAC;IACzB,QAAQ,EAAE,CAAC,MAAM,EAAE,kBAAkB,KAAK,IAAI,CAAC;IAC/C,OAAO,EAAE,OAAO,mBAAmB,CAAC;CACrC;AAED,wBAAgB,gBAAgB,CAAC,EAC/B,KAAK,EACL,QAAQ,EACR,OAAO,GACR,EAAE,qBAAqB,2CA6NvB"}
|
|
@@ -1,8 +1,7 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
2
|
import { useState, useCallback } from "react";
|
|
3
|
-
import { TextInput, Select
|
|
4
|
-
import { toast } from "@powerhousedao/design-system";
|
|
5
|
-
import {} from "../../document-models/payment-terms/index.js";
|
|
3
|
+
import { TextInput, Select } from "@powerhousedao/document-engineering";
|
|
4
|
+
import { Button, toast } from "@powerhousedao/design-system";
|
|
6
5
|
export function CostMaterialsTab({ state, dispatch, actions, }) {
|
|
7
6
|
const [isEditing, setIsEditing] = useState(false);
|
|
8
7
|
const [formData, setFormData] = useState({
|
|
@@ -44,7 +43,7 @@ export function CostMaterialsTab({ state, dispatch, actions, }) {
|
|
|
44
43
|
setIsEditing(false);
|
|
45
44
|
}, [state.costAndMaterials]);
|
|
46
45
|
if (!isEditing) {
|
|
47
|
-
return (_jsxs("div", { className: "space-y-6", children: [_jsxs("div", { className: "flex justify-between items-center mb-4", children: [_jsx("h2", { className: "text-xl font-semibold dark:text-white", children: "Cost & Materials Configuration" }), _jsx(Button, { onClick: () => setIsEditing(true), color: "light", size: "
|
|
46
|
+
return (_jsxs("div", { className: "space-y-6", children: [_jsxs("div", { className: "flex justify-between items-center mb-4", children: [_jsx("h2", { className: "text-xl font-semibold dark:text-white", children: "Cost & Materials Configuration" }), _jsx(Button, { onClick: () => setIsEditing(true), color: "light", size: "small", className: "cursor-pointer hover:bg-blue-600 hover:text-white", children: state.costAndMaterials
|
|
48
47
|
? "Edit Configuration"
|
|
49
48
|
: "Configure Cost & Materials" })] }), state.costAndMaterials ? (_jsxs("div", { className: "grid grid-cols-2 gap-6", children: [_jsxs("div", { children: [_jsx("label", { className: "block text-sm font-medium text-gray-700 dark:text-gray-300 mb-1", children: "Hourly Rate" }), _jsx("p", { className: "text-lg dark:text-white", children: state.costAndMaterials.hourlyRate
|
|
50
49
|
? `${state.costAndMaterials.hourlyRate.value} ${state.costAndMaterials.hourlyRate.unit}`
|
|
@@ -59,5 +58,5 @@ export function CostMaterialsTab({ state, dispatch, actions, }) {
|
|
|
59
58
|
{ value: "WEEKLY", label: "Weekly" },
|
|
60
59
|
{ value: "BIWEEKLY", label: "Biweekly" },
|
|
61
60
|
{ value: "MONTHLY", label: "Monthly" },
|
|
62
|
-
], placeholder: "Select billing frequency", required: true })] }), _jsxs("div", { className: "flex items-center pt-6", children: [_jsx("input", { type: "checkbox", id: "timesheetRequired", checked: formData.timesheetRequired, onChange: (e) => setFormData({ ...formData, timesheetRequired: e.target.checked }), className: "mr-2 h-4 w-4 text-blue-600 focus:ring-blue-500 border-gray-300 rounded" }), _jsx("label", { htmlFor: "timesheetRequired", className: "text-sm font-medium text-gray-700 dark:text-gray-300", children: "Timesheet Required" })] })] }), _jsxs("div", { className: "flex gap-3", children: [_jsx(Button, { type: "submit", color: "light", size: "
|
|
61
|
+
], placeholder: "Select billing frequency", required: true })] }), _jsxs("div", { className: "flex items-center pt-6", children: [_jsx("input", { type: "checkbox", id: "timesheetRequired", checked: formData.timesheetRequired, onChange: (e) => setFormData({ ...formData, timesheetRequired: e.target.checked }), className: "mr-2 h-4 w-4 text-blue-600 focus:ring-blue-500 border-gray-300 rounded" }), _jsx("label", { htmlFor: "timesheetRequired", className: "text-sm font-medium text-gray-700 dark:text-gray-300", children: "Timesheet Required" })] })] }), _jsxs("div", { className: "flex gap-3", children: [_jsx(Button, { type: "submit", color: "light", size: "small", className: "cursor-pointer hover:bg-blue-600 hover:text-white", children: "Save Configuration" }), _jsx(Button, { type: "button", onClick: handleCancel, color: "light", size: "small", className: "cursor-pointer hover:bg-gray-600 hover:text-white", children: "Cancel" })] })] }));
|
|
63
62
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"editor.d.ts","sourceRoot":"","sources":["../../../editors/payment-terms/editor.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"editor.d.ts","sourceRoot":"","sources":["../../../editors/payment-terms/editor.tsx"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAAU,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAe1D,MAAM,MAAM,MAAM,GAAG,WAAW,CAAC;AAEjC,MAAM,CAAC,OAAO,UAAU,MAAM,4CAsW7B"}
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
-
import {
|
|
3
|
-
import { Button, Icon, toast, ToastContainer, } from "@powerhousedao/design-system";
|
|
2
|
+
import { Icon, ToastContainer, } from "@powerhousedao/design-system";
|
|
4
3
|
import { actions, } from "../../document-models/payment-terms/index.js";
|
|
5
4
|
import { BasicTermsTab } from "./basic-terms-tab.js";
|
|
6
5
|
import { MilestonesTab } from "./milestones-tab.js";
|
|
@@ -10,7 +9,6 @@ import { RetainerTab } from "./retainer-tab.js";
|
|
|
10
9
|
import { EscrowTab } from "./escrow-tab.js";
|
|
11
10
|
import { EvaluationTab } from "./evaluation-tab.js";
|
|
12
11
|
import { useSelectedPaymentTermsDocument } from "../hooks/usePaymentTermsDocument.js";
|
|
13
|
-
import { DocumentToolbar } from "@powerhousedao/design-system";
|
|
14
12
|
export default function Editor() {
|
|
15
13
|
// Getting dispatch from props or selected document
|
|
16
14
|
const [doc, dispatch] = useSelectedPaymentTermsDocument();
|
|
@@ -46,13 +44,7 @@ export default function Editor() {
|
|
|
46
44
|
const totalMilestones = state.milestoneSchedule?.length || 0;
|
|
47
45
|
const completedMilestones = state.milestoneSchedule?.filter((m) => m.payoutStatus === "PAID").length ||
|
|
48
46
|
0;
|
|
49
|
-
|
|
50
|
-
const parentFolder = useParentFolderForSelectedNode();
|
|
51
|
-
// Set the selected node to the parent folder node (close the editor)
|
|
52
|
-
function handleClose() {
|
|
53
|
-
setSelectedNode(parentFolder?.id);
|
|
54
|
-
}
|
|
55
|
-
return (_jsxs(_Fragment, { children: [_jsx(DocumentToolbar, { document: doc, onClose: handleClose }), _jsx("div", { className: "min-h-screen bg-gray-50 dark:bg-gray-900", children: _jsxs("div", { className: "max-w-7xl mx-auto p-6", children: [_jsxs("div", { className: "bg-white dark:bg-gray-800 rounded-lg shadow-sm p-6 mb-6", children: [_jsxs("div", { className: "flex justify-between items-start", children: [_jsxs("div", { className: "flex items-center gap-3", children: [_jsx(Icon, { name: "CalendarTime", size: 32, className: "text-blue-600 dark:text-blue-400" }), _jsxs("div", { children: [_jsx("h1", { className: "text-3xl font-bold text-gray-900 dark:text-white mb-2", children: "Payment Terms Document" }), _jsx("p", { className: "text-gray-600 dark:text-gray-300", children: "Manage payment terms, milestones, and contract clauses" })] })] }), _jsxs("div", { className: `flex items-center gap-2 px-3 py-2 rounded-full font-medium ${getStatusColor(state.status)}`, children: [_jsx(Icon, { name: getStatusIcon(state.status), size: 16 }), state.status] })] }), _jsxs("div", { className: "grid grid-cols-2 md:grid-cols-4 gap-4 mt-6", children: [_jsxs("div", { className: "bg-gray-50 dark:bg-gray-700 p-4 rounded-lg border border-gray-200 dark:border-gray-600", children: [_jsxs("div", { className: "flex items-center gap-2 mb-2", children: [_jsx(Icon, { name: "BarChart", size: 16, className: "text-blue-600 dark:text-blue-400" }), _jsx("p", { className: "text-sm text-gray-600 dark:text-gray-300 font-medium", children: "Payment Model" })] }), _jsx("p", { className: "text-lg font-semibold dark:text-white", children: state.paymentModel.replace(/_/g, " ") })] }), _jsxs("div", { className: "bg-gray-50 dark:bg-gray-700 p-4 rounded-lg border border-gray-200 dark:border-gray-600", children: [_jsxs("div", { className: "flex items-center gap-2 mb-2", children: [_jsx(Icon, { name: "BarChart", size: 16, className: "text-green-600 dark:text-green-400" }), _jsx("p", { className: "text-sm text-gray-600 dark:text-gray-300 font-medium", children: "Currency" })] }), _jsx("p", { className: "text-lg font-semibold dark:text-white", children: state.currency })] }), _jsxs("div", { className: "bg-gray-50 dark:bg-gray-700 p-4 rounded-lg border border-gray-200 dark:border-gray-600", children: [_jsxs("div", { className: "flex items-center gap-2 mb-2", children: [_jsx(Icon, { name: "BarChart", size: 16, className: "text-yellow-600 dark:text-yellow-400" }), _jsx("p", { className: "text-sm text-gray-600 dark:text-gray-300 font-medium", children: "Total Amount" })] }), _jsx("p", { className: "text-lg font-semibold dark:text-white", children: state.totalAmount
|
|
47
|
+
return (_jsxs(_Fragment, { children: [_jsx("div", { className: "min-h-screen bg-gray-50 dark:bg-gray-900", children: _jsxs("div", { className: "max-w-7xl mx-auto p-6", children: [_jsxs("div", { className: "bg-white dark:bg-gray-800 rounded-lg shadow-sm p-6 mb-6", children: [_jsxs("div", { className: "flex justify-between items-start", children: [_jsxs("div", { className: "flex items-center gap-3", children: [_jsx(Icon, { name: "CalendarTime", size: 32, className: "text-blue-600 dark:text-blue-400" }), _jsxs("div", { children: [_jsx("h1", { className: "text-3xl font-bold text-gray-900 dark:text-white mb-2", children: "Payment Terms Document" }), _jsx("p", { className: "text-gray-600 dark:text-gray-300", children: "Manage payment terms, milestones, and contract clauses" })] })] }), _jsxs("div", { className: `flex items-center gap-2 px-3 py-2 rounded-full font-medium ${getStatusColor(state.status)}`, children: [_jsx(Icon, { name: getStatusIcon(state.status), size: 16 }), state.status] })] }), _jsxs("div", { className: "grid grid-cols-2 md:grid-cols-4 gap-4 mt-6", children: [_jsxs("div", { className: "bg-gray-50 dark:bg-gray-700 p-4 rounded-lg border border-gray-200 dark:border-gray-600", children: [_jsxs("div", { className: "flex items-center gap-2 mb-2", children: [_jsx(Icon, { name: "BarChart", size: 16, className: "text-blue-600 dark:text-blue-400" }), _jsx("p", { className: "text-sm text-gray-600 dark:text-gray-300 font-medium", children: "Payment Model" })] }), _jsx("p", { className: "text-lg font-semibold dark:text-white", children: state.paymentModel.replace(/_/g, " ") })] }), _jsxs("div", { className: "bg-gray-50 dark:bg-gray-700 p-4 rounded-lg border border-gray-200 dark:border-gray-600", children: [_jsxs("div", { className: "flex items-center gap-2 mb-2", children: [_jsx(Icon, { name: "BarChart", size: 16, className: "text-green-600 dark:text-green-400" }), _jsx("p", { className: "text-sm text-gray-600 dark:text-gray-300 font-medium", children: "Currency" })] }), _jsx("p", { className: "text-lg font-semibold dark:text-white", children: state.currency })] }), _jsxs("div", { className: "bg-gray-50 dark:bg-gray-700 p-4 rounded-lg border border-gray-200 dark:border-gray-600", children: [_jsxs("div", { className: "flex items-center gap-2 mb-2", children: [_jsx(Icon, { name: "BarChart", size: 16, className: "text-yellow-600 dark:text-yellow-400" }), _jsx("p", { className: "text-sm text-gray-600 dark:text-gray-300 font-medium", children: "Total Amount" })] }), _jsx("p", { className: "text-lg font-semibold dark:text-white", children: state.totalAmount
|
|
56
48
|
? `${state.totalAmount.value} ${state.totalAmount.unit}`
|
|
57
49
|
: "Not set" })] }), _jsxs("div", { className: "bg-gray-50 dark:bg-gray-700 p-4 rounded-lg border border-gray-200 dark:border-gray-600", children: [_jsxs("div", { className: "flex items-center gap-2 mb-2", children: [_jsx(Icon, { name: "BarChart", size: 16, className: "text-purple-600 dark:text-purple-400" }), _jsx("p", { className: "text-sm text-gray-600 dark:text-gray-300 font-medium", children: "Progress" })] }), _jsx("p", { className: "text-lg font-semibold dark:text-white", children: state.paymentModel === "MILESTONE"
|
|
58
50
|
? `${completedMilestones} / ${totalMilestones}`
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import type { PaymentTermsState } from "../../document-models/payment-terms/gen/schema/types.js";
|
|
2
2
|
import type { PaymentTermsAction } from "../../document-models/payment-terms/gen/actions.js";
|
|
3
|
-
import {
|
|
3
|
+
import { actions as paymentTermsActions } from "../../document-models/payment-terms/index.js";
|
|
4
4
|
export interface EscrowTabProps {
|
|
5
5
|
state: PaymentTermsState;
|
|
6
6
|
dispatch: (action: PaymentTermsAction) => void;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"escrow-tab.d.ts","sourceRoot":"","sources":["../../../editors/payment-terms/escrow-tab.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"escrow-tab.d.ts","sourceRoot":"","sources":["../../../editors/payment-terms/escrow-tab.tsx"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,yDAAyD,CAAC;AACjG,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,oDAAoD,CAAC;AAC7F,OAAO,EAAE,OAAO,IAAI,mBAAmB,EAAE,MAAM,8CAA8C,CAAC;AAE9F,MAAM,WAAW,cAAc;IAC7B,KAAK,EAAE,iBAAiB,CAAC;IACzB,QAAQ,EAAE,CAAC,MAAM,EAAE,kBAAkB,KAAK,IAAI,CAAC;IAC/C,OAAO,EAAE,OAAO,mBAAmB,CAAC;CACrC;AAED,wBAAgB,SAAS,CAAC,EAAE,KAAK,EAAE,QAAQ,EAAE,OAAO,EAAE,EAAE,cAAc,2CA4LrE"}
|
|
@@ -1,8 +1,7 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
2
|
import { useState, useCallback } from "react";
|
|
3
|
-
import { TextInput, Textarea
|
|
4
|
-
import { toast } from "@powerhousedao/design-system";
|
|
5
|
-
import {} from "../../document-models/payment-terms/index.js";
|
|
3
|
+
import { TextInput, Textarea } from "@powerhousedao/document-engineering";
|
|
4
|
+
import { Button, toast } from "@powerhousedao/design-system";
|
|
6
5
|
export function EscrowTab({ state, dispatch, actions }) {
|
|
7
6
|
const [isEditing, setIsEditing] = useState(false);
|
|
8
7
|
const [formData, setFormData] = useState({
|
|
@@ -49,7 +48,7 @@ export function EscrowTab({ state, dispatch, actions }) {
|
|
|
49
48
|
setIsEditing(false);
|
|
50
49
|
}, [state.escrowDetails]);
|
|
51
50
|
if (!isEditing) {
|
|
52
|
-
return (_jsxs("div", { className: "space-y-6", children: [_jsxs("div", { className: "flex justify-between items-center mb-4", children: [_jsx("h2", { className: "text-xl font-semibold dark:text-white", children: "Escrow Configuration" }), _jsx(Button, { onClick: () => setIsEditing(true), color: "light", size: "
|
|
51
|
+
return (_jsxs("div", { className: "space-y-6", children: [_jsxs("div", { className: "flex justify-between items-center mb-4", children: [_jsx("h2", { className: "text-xl font-semibold dark:text-white", children: "Escrow Configuration" }), _jsx(Button, { onClick: () => setIsEditing(true), color: "light", size: "small", className: "cursor-pointer hover:bg-blue-600 hover:text-white", children: state.escrowDetails ? "Edit Escrow" : "Configure Escrow" })] }), state.escrowDetails && state.escrowDetails.releaseConditions ? (_jsxs("div", { className: "grid grid-cols-2 gap-6", children: [_jsxs("div", { children: [_jsx("label", { className: "block text-sm font-medium text-gray-700 dark:text-gray-300 mb-1", children: "Amount Held" }), _jsx("p", { className: "text-lg dark:text-white", children: state.escrowDetails.amountHeld
|
|
53
52
|
? `${state.escrowDetails.amountHeld.value} ${state.escrowDetails.amountHeld.unit}`
|
|
54
53
|
: "Not set" })] }), _jsxs("div", { children: [_jsx("label", { className: "block text-sm font-medium text-gray-700 dark:text-gray-300 mb-1", children: "Escrow Provider" }), _jsx("p", { className: "text-lg dark:text-white", children: state.escrowDetails.escrowProvider || "Not specified" })] }), _jsxs("div", { children: [_jsx("label", { className: "block text-sm font-medium text-gray-700 dark:text-gray-300 mb-1", children: "Proof of Funds Document ID" }), _jsx("p", { className: "text-lg font-mono text-sm dark:text-white", children: state.escrowDetails.proofOfFundsDocumentId || "Not provided" })] }), _jsxs("div", { className: "col-span-1", children: [_jsx("label", { className: "block text-sm font-medium text-gray-700 dark:text-gray-300 mb-1", children: "Release Conditions" }), _jsx("div", { className: "bg-gray-50 dark:bg-gray-700 p-3 rounded border dark:border-gray-600", children: _jsx("p", { className: "text-sm dark:text-white", children: state.escrowDetails.releaseConditions }) })] })] })) : (_jsxs("div", { className: "text-center py-8 text-gray-500 dark:text-gray-400", children: [_jsx("p", { children: "No escrow configuration set up yet." }), _jsx("p", { className: "text-sm", children: "Click \"Configure Escrow\" to get started." })] }))] }));
|
|
55
54
|
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import type { PaymentTermsState } from "../../document-models/payment-terms/gen/schema/types.js";
|
|
2
2
|
import type { PaymentTermsAction } from "../../document-models/payment-terms/gen/actions.js";
|
|
3
|
-
import {
|
|
3
|
+
import { actions as paymentTermsActions } from "../../document-models/payment-terms/index.js";
|
|
4
4
|
export interface EvaluationTabProps {
|
|
5
5
|
state: PaymentTermsState;
|
|
6
6
|
dispatch: (action: PaymentTermsAction) => void;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"evaluation-tab.d.ts","sourceRoot":"","sources":["../../../editors/payment-terms/evaluation-tab.tsx"],"names":[],"mappings":"AAGA,OAAO,KAAK,EACV,iBAAiB,EAElB,MAAM,yDAAyD,CAAC;AACjE,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,oDAAoD,CAAC;AAC7F,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"evaluation-tab.d.ts","sourceRoot":"","sources":["../../../editors/payment-terms/evaluation-tab.tsx"],"names":[],"mappings":"AAGA,OAAO,KAAK,EACV,iBAAiB,EAElB,MAAM,yDAAyD,CAAC;AACjE,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,oDAAoD,CAAC;AAC7F,OAAO,EAAE,OAAO,IAAI,mBAAmB,EAAE,MAAM,8CAA8C,CAAC;AAE9F,MAAM,WAAW,kBAAkB;IACjC,KAAK,EAAE,iBAAiB,CAAC;IACzB,QAAQ,EAAE,CAAC,MAAM,EAAE,kBAAkB,KAAK,IAAI,CAAC;IAC/C,OAAO,EAAE,OAAO,mBAAmB,CAAC;CACrC;AAED,wBAAgB,aAAa,CAAC,EAAE,KAAK,EAAE,QAAQ,EAAE,OAAO,EAAE,EAAE,kBAAkB,2CA2N7E"}
|
|
@@ -1,8 +1,7 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
2
|
import { useState, useCallback, useMemo } from "react";
|
|
3
|
-
import { TextInput, Select, Textarea
|
|
4
|
-
import { toast } from "@powerhousedao/design-system";
|
|
5
|
-
import {} from "../../document-models/payment-terms/index.js";
|
|
3
|
+
import { TextInput, Select, Textarea } from "@powerhousedao/document-engineering";
|
|
4
|
+
import { Button, toast } from "@powerhousedao/design-system";
|
|
6
5
|
export function EvaluationTab({ state, dispatch, actions }) {
|
|
7
6
|
const [isEditing, setIsEditing] = useState(false);
|
|
8
7
|
const [formData, setFormData] = useState({
|
|
@@ -57,7 +56,7 @@ export function EvaluationTab({ state, dispatch, actions }) {
|
|
|
57
56
|
setIsEditing(false);
|
|
58
57
|
}, [state.evaluation]);
|
|
59
58
|
if (!isEditing) {
|
|
60
|
-
return (_jsxs("div", { className: "space-y-6", children: [_jsxs("div", { className: "flex justify-between items-center mb-4", children: [_jsx("h2", { className: "text-xl font-semibold dark:text-white", children: "Evaluation Terms" }), _jsx(Button, { onClick: () => setIsEditing(true), color: "light", size: "
|
|
59
|
+
return (_jsxs("div", { className: "space-y-6", children: [_jsxs("div", { className: "flex justify-between items-center mb-4", children: [_jsx("h2", { className: "text-xl font-semibold dark:text-white", children: "Evaluation Terms" }), _jsx(Button, { onClick: () => setIsEditing(true), color: "light", size: "small", className: "cursor-pointer hover:bg-blue-600 hover:text-white", children: state.evaluation ? "Edit Terms" : "Configure Evaluation" })] }), state.evaluation ? (_jsxs("div", { className: "grid grid-cols-2 gap-6", children: [_jsxs("div", { children: [_jsx("label", { className: "block text-sm font-medium text-gray-700 dark:text-gray-300 mb-1", children: "Evaluation Frequency" }), _jsx("p", { className: "text-lg dark:text-white", children: state.evaluation.evaluationFrequency })] }), _jsxs("div", { children: [_jsx("label", { className: "block text-sm font-medium text-gray-700 dark:text-gray-300 mb-1", children: "Evaluator Team" }), _jsx("p", { className: "text-lg dark:text-white", children: state.evaluation.evaluatorTeam })] }), _jsxs("div", { children: [_jsx("label", { className: "block text-sm font-medium text-gray-700 dark:text-gray-300 mb-1", children: "Impacts Payout" }), _jsx("p", { className: "text-lg dark:text-white", children: state.evaluation.impactsPayout ? "Yes" : "No" })] }), _jsxs("div", { children: [_jsx("label", { className: "block text-sm font-medium text-gray-700 dark:text-gray-300 mb-1", children: "Impacts Reputation" }), _jsx("p", { className: "text-lg dark:text-white", children: state.evaluation.impactsReputation ? "Yes" : "No" })] }), _jsxs("div", { children: [_jsx("label", { className: "block text-sm font-medium text-gray-700 dark:text-gray-300 mb-1", children: "Comments Visible to Client" }), _jsx("p", { className: "text-lg dark:text-white", children: state.evaluation.commentsVisibleToClient ? "Yes" : "No" })] }), _jsxs("div", { className: "col-span-2", children: [_jsx("label", { className: "block text-sm font-medium text-gray-700 dark:text-gray-300 mb-1", children: "Evaluation Criteria" }), _jsx("div", { className: "bg-gray-50 dark:bg-gray-700 p-3 rounded border dark:border-gray-600", children: _jsx("ul", { className: "list-disc list-inside text-sm space-y-1", children: state.evaluation.criteria.map((criterion, index) => (_jsx("li", { children: criterion }, index))) }) })] })] })) : (_jsxs("div", { className: "text-center py-8 text-gray-500 dark:text-gray-400", children: [_jsx("p", { children: "No evaluation terms configured yet." }), _jsx("p", { className: "text-sm", children: "Click \"Configure Evaluation\" to get started." })] }))] }));
|
|
61
60
|
}
|
|
62
|
-
return (_jsxs("form", { onSubmit: handleSubmit, className: "space-y-6", children: [_jsx("div", { className: "flex justify-between items-center mb-4", children: _jsx("h2", { className: "text-xl font-semibold dark:text-white", children: "Configure Evaluation Terms" }) }), _jsxs("div", { className: "grid grid-cols-2 gap-6", children: [_jsx(Select, { label: "Evaluation Frequency *", options: evaluationFrequencyOptions, value: formData.evaluationFrequency, onChange: (value) => setFormData({ ...formData, evaluationFrequency: value }) }), _jsx(TextInput, { label: "Evaluator Team *", value: formData.evaluatorTeam, onChange: (e) => setFormData({ ...formData, evaluatorTeam: e.target.value }), className: "w-full", placeholder: "e.g., Product Team", required: true }), _jsx("div", { className: "col-span-2", children: _jsx(Textarea, { label: "Evaluation Criteria * (one per line)", value: formData.criteria, onChange: (e) => setFormData({ ...formData, criteria: e.target.value }), className: "w-full", rows: 6, placeholder: "Enter each evaluation criterion on a separate line...", required: true }) }), _jsxs("div", { className: "col-span-2 space-y-4", children: [_jsx("h3", { className: "text-lg font-medium dark:text-white", children: "Impact Settings" }), _jsxs("div", { className: "flex items-center", children: [_jsx("input", { type: "checkbox", id: "impactsPayout", checked: formData.impactsPayout, onChange: (e) => setFormData({ ...formData, impactsPayout: e.target.checked }), className: "mr-2 h-4 w-4 text-blue-600 focus:ring-blue-500 border-gray-300 rounded" }), _jsx("label", { htmlFor: "impactsPayout", className: "text-sm font-medium text-gray-700 dark:text-gray-300", children: "Evaluation results impact payout" })] }), _jsxs("div", { className: "flex items-center", children: [_jsx("input", { type: "checkbox", id: "impactsReputation", checked: formData.impactsReputation, onChange: (e) => setFormData({ ...formData, impactsReputation: e.target.checked }), className: "mr-2 h-4 w-4 text-blue-600 focus:ring-blue-500 border-gray-300 rounded" }), _jsx("label", { htmlFor: "impactsReputation", className: "text-sm font-medium text-gray-700 dark:text-gray-300", children: "Evaluation results impact reputation" })] }), _jsxs("div", { className: "flex items-center", children: [_jsx("input", { type: "checkbox", id: "commentsVisibleToClient", checked: formData.commentsVisibleToClient, onChange: (e) => setFormData({ ...formData, commentsVisibleToClient: e.target.checked }), className: "mr-2 h-4 w-4 text-blue-600 focus:ring-blue-500 border-gray-300 rounded" }), _jsx("label", { htmlFor: "commentsVisibleToClient", className: "text-sm font-medium text-gray-700 dark:text-gray-300", children: "Evaluation comments visible to client" })] })] })] }), _jsxs("div", { className: "flex gap-3", children: [_jsx(Button, { type: "submit", color: "light", size: "
|
|
61
|
+
return (_jsxs("form", { onSubmit: handleSubmit, className: "space-y-6", children: [_jsx("div", { className: "flex justify-between items-center mb-4", children: _jsx("h2", { className: "text-xl font-semibold dark:text-white", children: "Configure Evaluation Terms" }) }), _jsxs("div", { className: "grid grid-cols-2 gap-6", children: [_jsx(Select, { label: "Evaluation Frequency *", options: evaluationFrequencyOptions, value: formData.evaluationFrequency, onChange: (value) => setFormData({ ...formData, evaluationFrequency: value }) }), _jsx(TextInput, { label: "Evaluator Team *", value: formData.evaluatorTeam, onChange: (e) => setFormData({ ...formData, evaluatorTeam: e.target.value }), className: "w-full", placeholder: "e.g., Product Team", required: true }), _jsx("div", { className: "col-span-2", children: _jsx(Textarea, { label: "Evaluation Criteria * (one per line)", value: formData.criteria, onChange: (e) => setFormData({ ...formData, criteria: e.target.value }), className: "w-full", rows: 6, placeholder: "Enter each evaluation criterion on a separate line...", required: true }) }), _jsxs("div", { className: "col-span-2 space-y-4", children: [_jsx("h3", { className: "text-lg font-medium dark:text-white", children: "Impact Settings" }), _jsxs("div", { className: "flex items-center", children: [_jsx("input", { type: "checkbox", id: "impactsPayout", checked: formData.impactsPayout, onChange: (e) => setFormData({ ...formData, impactsPayout: e.target.checked }), className: "mr-2 h-4 w-4 text-blue-600 focus:ring-blue-500 border-gray-300 rounded" }), _jsx("label", { htmlFor: "impactsPayout", className: "text-sm font-medium text-gray-700 dark:text-gray-300", children: "Evaluation results impact payout" })] }), _jsxs("div", { className: "flex items-center", children: [_jsx("input", { type: "checkbox", id: "impactsReputation", checked: formData.impactsReputation, onChange: (e) => setFormData({ ...formData, impactsReputation: e.target.checked }), className: "mr-2 h-4 w-4 text-blue-600 focus:ring-blue-500 border-gray-300 rounded" }), _jsx("label", { htmlFor: "impactsReputation", className: "text-sm font-medium text-gray-700 dark:text-gray-300", children: "Evaluation results impact reputation" })] }), _jsxs("div", { className: "flex items-center", children: [_jsx("input", { type: "checkbox", id: "commentsVisibleToClient", checked: formData.commentsVisibleToClient, onChange: (e) => setFormData({ ...formData, commentsVisibleToClient: e.target.checked }), className: "mr-2 h-4 w-4 text-blue-600 focus:ring-blue-500 border-gray-300 rounded" }), _jsx("label", { htmlFor: "commentsVisibleToClient", className: "text-sm font-medium text-gray-700 dark:text-gray-300", children: "Evaluation comments visible to client" })] })] })] }), _jsxs("div", { className: "flex gap-3", children: [_jsx(Button, { type: "submit", color: "light", size: "small", className: "cursor-pointer hover:bg-blue-600 hover:text-white", children: "Save Evaluation Terms" }), _jsx(Button, { type: "button", onClick: handleCancel, color: "light", size: "small", className: "cursor-pointer hover:bg-gray-600 hover:text-white", children: "Cancel" })] })] }));
|
|
63
62
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../editors/payment-terms/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAGnD,eAAO,MAAM,MAAM,EAAE,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../editors/payment-terms/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAGnD,eAAO,MAAM,MAAM,EAAE,YASpB,CAAC;AAEF,eAAe,MAAM,CAAC"}
|
|
@@ -4,7 +4,9 @@ export const module = {
|
|
|
4
4
|
documentTypes: ["payment-terms"],
|
|
5
5
|
config: {
|
|
6
6
|
id: "payment-terms-editor",
|
|
7
|
-
|
|
7
|
+
disableExternalControls: true,
|
|
8
|
+
documentToolbarEnabled: true,
|
|
9
|
+
showSwitchboardLink: true,
|
|
8
10
|
},
|
|
9
11
|
};
|
|
10
12
|
export default module;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import type { Milestone, PaymentTermsAction } from "../../document-models/payment-terms/gen/types.js";
|
|
2
|
-
import {
|
|
2
|
+
import { actions as paymentTermsActions } from "../../document-models/payment-terms/index.js";
|
|
3
3
|
export interface MilestonesTabProps {
|
|
4
4
|
milestones: Milestone[];
|
|
5
5
|
dispatch: (action: PaymentTermsAction) => void;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"milestones-tab.d.ts","sourceRoot":"","sources":["../../../editors/payment-terms/milestones-tab.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"milestones-tab.d.ts","sourceRoot":"","sources":["../../../editors/payment-terms/milestones-tab.tsx"],"names":[],"mappings":"AAYA,OAAO,KAAK,EACV,SAAS,EAET,kBAAkB,EACnB,MAAM,kDAAkD,CAAC;AAC1D,OAAO,EAAE,OAAO,IAAI,mBAAmB,EAAE,MAAM,8CAA8C,CAAC;AAE9F,MAAM,WAAW,kBAAkB;IACjC,UAAU,EAAE,SAAS,EAAE,CAAC;IACxB,QAAQ,EAAE,CAAC,MAAM,EAAE,kBAAkB,KAAK,IAAI,CAAC;IAC/C,OAAO,EAAE,OAAO,mBAAmB,CAAC;IACpC,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED,wBAAgB,aAAa,CAAC,EAC5B,UAAU,EACV,QAAQ,EACR,OAAO,EACP,QAAgB,GACjB,EAAE,kBAAkB,2CA+VpB"}
|
|
@@ -1,10 +1,8 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
2
|
import { useState, useCallback, useMemo } from "react";
|
|
3
3
|
import { ObjectSetTable, TextInput, DatePicker, } from "@powerhousedao/document-engineering";
|
|
4
|
-
import { Button, } from "@powerhousedao/
|
|
5
|
-
import {
|
|
6
|
-
import { generateId } from "document-model/core";
|
|
7
|
-
import {} from "../../document-models/payment-terms/index.js";
|
|
4
|
+
import { Button, Icon, toast } from "@powerhousedao/design-system";
|
|
5
|
+
import { generateId } from "document-model";
|
|
8
6
|
export function MilestonesTab({ milestones, dispatch, actions, currency = "USD", }) {
|
|
9
7
|
const [isAddingNew, setIsAddingNew] = useState(false);
|
|
10
8
|
const [newMilestone, setNewMilestone] = useState({
|
|
@@ -133,7 +131,7 @@ export function MilestonesTab({ milestones, dispatch, actions, currency = "USD",
|
|
|
133
131
|
toast("Milestone deleted", {
|
|
134
132
|
type: "success",
|
|
135
133
|
});
|
|
136
|
-
}, size: "
|
|
134
|
+
}, size: "small", className: "text-red-600 hover:text-red-800", children: _jsx(Icon, { name: "Trash", size: 16 }) })),
|
|
137
135
|
},
|
|
138
136
|
], [actions, currency, dispatch]);
|
|
139
137
|
const handleAddMilestone = useCallback((e) => {
|
|
@@ -177,7 +175,7 @@ export function MilestonesTab({ milestones, dispatch, actions, currency = "USD",
|
|
|
177
175
|
});
|
|
178
176
|
setIsAddingNew(false);
|
|
179
177
|
}, [newMilestone, dispatch, actions, currency]);
|
|
180
|
-
return (_jsxs("div", { className: "space-y-6", children: [_jsxs("div", { className: "flex justify-between items-center", children: [_jsxs("div", { children: [_jsx("h2", { className: "text-xl font-semibold dark:text-white", children: "Milestones" }), _jsxs("p", { className: "text-sm text-gray-600 dark:text-gray-300 mt-1", children: [milestones.length, " milestone(s) defined"] })] }), _jsxs(Button, { onClick: () => setIsAddingNew(!isAddingNew), color: "light", size: "
|
|
178
|
+
return (_jsxs("div", { className: "space-y-6", children: [_jsxs("div", { className: "flex justify-between items-center", children: [_jsxs("div", { children: [_jsx("h2", { className: "text-xl font-semibold dark:text-white", children: "Milestones" }), _jsxs("p", { className: "text-sm text-gray-600 dark:text-gray-300 mt-1", children: [milestones.length, " milestone(s) defined"] })] }), _jsxs(Button, { onClick: () => setIsAddingNew(!isAddingNew), color: "light", size: "small", className: "cursor-pointer hover:bg-blue-600 hover:text-white", children: [_jsx(Icon, { name: "Plus", size: 16, className: "mr-2" }), "Add Milestone"] })] }), isAddingNew && (_jsxs("div", { className: "bg-gray-50 dark:bg-gray-700 p-4 rounded-lg border dark:border-gray-600", children: [_jsx("h3", { className: "text-lg font-medium mb-4 dark:text-white", children: "Add New Milestone" }), _jsxs("form", { onSubmit: handleAddMilestone, className: "space-y-4", children: [_jsxs("div", { className: "grid grid-cols-2 gap-4", children: [_jsx(TextInput, { label: "Name *", value: newMilestone.name, onChange: (e) => setNewMilestone({ ...newMilestone, name: e.target.value }), className: "w-full", required: true }), _jsx(TextInput, { label: `Amount (${currency}) *`, type: "number", value: newMilestone.amount, onChange: (e) => setNewMilestone({ ...newMilestone, amount: e.target.value }), className: "w-full", placeholder: "0.00", step: "0.01", required: true }), _jsx(DatePicker, { value: newMilestone.expectedCompletionDate
|
|
181
179
|
? new Date(newMilestone.expectedCompletionDate)
|
|
182
180
|
: undefined, onChange: (e) => {
|
|
183
181
|
const date = e.target.value ? new Date(e.target.value) : null;
|
|
@@ -188,7 +186,7 @@ export function MilestonesTab({ milestones, dispatch, actions, currency = "USD",
|
|
|
188
186
|
}, name: "expected-completion-date", placeholder: "Select expected completion date" }), _jsxs("div", { className: "flex items-center pt-6", children: [_jsx("input", { type: "checkbox", id: "requiresApproval", checked: newMilestone.requiresApproval, onChange: (e) => setNewMilestone({
|
|
189
187
|
...newMilestone,
|
|
190
188
|
requiresApproval: e.target.checked,
|
|
191
|
-
}), className: "mr-2 h-4 w-4 text-blue-600 focus:ring-blue-500 border-gray-300 rounded" }), _jsx("label", { htmlFor: "requiresApproval", className: "text-sm font-medium text-gray-700 dark:text-gray-300", children: "Requires Approval" })] })] }), _jsxs("div", { className: "flex gap-3", children: [_jsx(Button, { type: "submit", color: "light", size: "
|
|
189
|
+
}), className: "mr-2 h-4 w-4 text-blue-600 focus:ring-blue-500 border-gray-300 rounded" }), _jsx("label", { htmlFor: "requiresApproval", className: "text-sm font-medium text-gray-700 dark:text-gray-300", children: "Requires Approval" })] })] }), _jsxs("div", { className: "flex gap-3", children: [_jsx(Button, { type: "submit", color: "light", size: "small", className: "cursor-pointer hover:bg-blue-600 hover:text-white", children: "Add Milestone" }), _jsx(Button, { type: "button", onClick: () => {
|
|
192
190
|
setIsAddingNew(false);
|
|
193
191
|
setNewMilestone({
|
|
194
192
|
name: "",
|
|
@@ -196,7 +194,7 @@ export function MilestonesTab({ milestones, dispatch, actions, currency = "USD",
|
|
|
196
194
|
expectedCompletionDate: "",
|
|
197
195
|
requiresApproval: true,
|
|
198
196
|
});
|
|
199
|
-
}, color: "light", size: "
|
|
197
|
+
}, color: "light", size: "small", className: "cursor-pointer hover:bg-gray-600 hover:text-white", children: "Cancel" })] })] })] })), milestones.length > 0 ? (_jsx(ObjectSetTable, { data: milestones, columns: columns, onAdd: () => setIsAddingNew(true), onDelete: (row) => {
|
|
200
198
|
dispatch(actions.deleteMilestone({ id: row.id }));
|
|
201
199
|
toast("Milestone deleted", {
|
|
202
200
|
type: "success",
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import type { PaymentTermsState } from "../../document-models/payment-terms/gen/schema/types.js";
|
|
2
2
|
import type { PaymentTermsAction } from "../../document-models/payment-terms/gen/actions.js";
|
|
3
|
-
import {
|
|
3
|
+
import { actions as paymentTermsActions } from "../../document-models/payment-terms/index.js";
|
|
4
4
|
export interface RetainerTabProps {
|
|
5
5
|
state: PaymentTermsState;
|
|
6
6
|
dispatch: (action: PaymentTermsAction) => void;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"retainer-tab.d.ts","sourceRoot":"","sources":["../../../editors/payment-terms/retainer-tab.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"retainer-tab.d.ts","sourceRoot":"","sources":["../../../editors/payment-terms/retainer-tab.tsx"],"names":[],"mappings":"AAQA,OAAO,KAAK,EACV,iBAAiB,EAElB,MAAM,yDAAyD,CAAC;AACjE,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,oDAAoD,CAAC;AAC7F,OAAO,EAAE,OAAO,IAAI,mBAAmB,EAAE,MAAM,8CAA8C,CAAC;AAE9F,MAAM,WAAW,gBAAgB;IAC/B,KAAK,EAAE,iBAAiB,CAAC;IACzB,QAAQ,EAAE,CAAC,MAAM,EAAE,kBAAkB,KAAK,IAAI,CAAC;IAC/C,OAAO,EAAE,OAAO,mBAAmB,CAAC;CACrC;AAED,wBAAgB,WAAW,CAAC,EAAE,KAAK,EAAE,QAAQ,EAAE,OAAO,EAAE,EAAE,gBAAgB,2CA+RzE"}
|