From a82b5a6992fda61d6eaa0bb079e284805a394777 Mon Sep 17 00:00:00 2001
From: Sebastian
Date: Wed, 3 Nov 2021 17:30:11 -0300
Subject: feedback from meeting and editing policy
---
.../src/pages/home/ReviewPoliciesScreen.tsx | 57 +++++++++++++++++-----
1 file changed, 44 insertions(+), 13 deletions(-)
(limited to 'packages/anastasis-webui/src/pages/home/ReviewPoliciesScreen.tsx')
diff --git a/packages/anastasis-webui/src/pages/home/ReviewPoliciesScreen.tsx b/packages/anastasis-webui/src/pages/home/ReviewPoliciesScreen.tsx
index 673f215e2..b8beb7b47 100644
--- a/packages/anastasis-webui/src/pages/home/ReviewPoliciesScreen.tsx
+++ b/packages/anastasis-webui/src/pages/home/ReviewPoliciesScreen.tsx
@@ -1,10 +1,14 @@
/* eslint-disable @typescript-eslint/camelcase */
+import { AuthMethod } from "anastasis-core";
import { h, VNode } from "preact";
+import { useState } from "preact/hooks";
import { useAnastasisContext } from "../../context/anastasis";
-import { AnastasisClientFrame } from "./index";
import { authMethods, KnownAuthMethods } from "./authMethod";
+import { EditPoliciesScreen } from "./EditPoliciesScreen";
+import { AnastasisClientFrame } from "./index";
export function ReviewPoliciesScreen(): VNode {
+ const [editingPolicy, setEditingPolicy] = useState()
const reducer = useAnastasisContext()
if (!reducer) {
return no reducer in context
@@ -12,20 +16,44 @@ export function ReviewPoliciesScreen(): VNode {
if (!reducer.currentReducerState || reducer.currentReducerState.backup_state === undefined) {
return invalid state
}
+
const configuredAuthMethods = reducer.currentReducerState.authentication_methods ?? [];
const policies = reducer.currentReducerState.policies ?? [];
+ if (editingPolicy !== undefined) {
+ return (
+ setEditingPolicy(undefined)}
+ confirm={(newMethods) => {
+ reducer.runTransaction(async (tx) => {
+ await tx.transition("delete_policy", {
+ policy_index: editingPolicy
+ });
+ await tx.transition("add_policy", {
+ policy: newMethods
+ });
+ });
+ setEditingPolicy(undefined)
+ }}
+ />
+ )
+ }
+
const errors = policies.length < 1 ? 'Need more policies' : undefined
return (
{policies.length > 0 &&
Based on your configured authentication method you have created, some policies
- have been configured. In order to recover your secret you have to solve all the
+ have been configured. In order to recover your secret you have to solve all the
challenges of at least one policy.
-
}
+
}
{policies.length < 1 &&
No policies had been created. Go back and add more authentication methods.
-
}
+ }
+ setEditingPolicy(policies.length + 1)}>
+ Add new policy
+
{policies.map((p, policy_index) => {
const methods = p.methods
.map(x => configuredAuthMethods[x.authentication_method] && ({ ...configuredAuthMethods[x.authentication_method], provider: x.provider }))
@@ -44,18 +72,21 @@ export function ReviewPoliciesScreen(): VNode {
}
{methods.map((m, i) => {
return (
-
-
- {authMethods[m.type as KnownAuthMethods]?.icon}
-
-
- {m.instructions} recovery provided by {m.provider}
-
-
+
+
+ {authMethods[m.type as KnownAuthMethods]?.icon}
+
+
+ {m.instructions} recovery provided by {m.provider}
+
+
);
})}
- reducer.transition("delete_policy", { policy_index })}>Delete
+
+ setEditingPolicy(policy_index)}>Edit
+ reducer.transition("delete_policy", { policy_index })}>Delete
+
);
})}
--
cgit v1.2.3