-
Notifications
You must be signed in to change notification settings - Fork 2
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat: Capture
node_data
directly alongside feeback (#3156)
- Loading branch information
1 parent
4eeea8f
commit 84d8476
Showing
9 changed files
with
195 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -239,6 +239,7 @@ | |
- feedback_type | ||
- flow_id | ||
- id | ||
- node_data | ||
- node_id | ||
- node_type | ||
- status | ||
|
3 changes: 3 additions & 0 deletions
3
...anx.uk/migrations/1715867685564_alter_table_public_feedback_add_column_node_data/down.sql
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
comment on column "public"."feedback"."node_data" is NULL; | ||
|
||
ALTER TABLE feedback DROP COLUMN node_data; |
4 changes: 4 additions & 0 deletions
4
...planx.uk/migrations/1715867685564_alter_table_public_feedback_add_column_node_data/up.sql
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
alter table "public"."feedback" add column "node_data" jsonb | ||
null; | ||
|
||
comment on column "public"."feedback"."node_data" is E'The data of the node the user was on when their feedback was left'; |
54 changes: 54 additions & 0 deletions
54
hasura.planx.uk/migrations/1715868696352_run_sql_migration/down.sql
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,54 @@ | ||
DROP VIEW "public"."feedback_summary"; | ||
|
||
-- Most recent version of view from planx-new/hasura.planx.uk/migrations/1715784133713_run_sql_migration/up.sql | ||
CREATE OR REPLACE VIEW "public"."feedback_summary" AS | ||
SELECT | ||
fb.id AS feedback_id, | ||
t.slug AS team, | ||
f.slug AS service_slug, | ||
fb.created_at, | ||
fb.node_id, | ||
fb.device, | ||
fb.user_context, | ||
fb.user_comment, | ||
fb.feedback_type, | ||
fb.status, | ||
fb.node_type, | ||
COALESCE( | ||
published_flow_node.data ->> 'title', | ||
published_flow_node.data ->> 'text', | ||
published_flow_node.data ->> 'flagSet' | ||
) AS node_title, | ||
published_flow_node.data ->> 'description' AS node_text, | ||
published_flow_node.data ->> 'info' AS help_text, | ||
published_flow_node.data ->> 'policyRef' AS help_sources, | ||
published_flow_node.data ->> 'howMeasured' AS help_definition, | ||
COALESCE( | ||
fb.user_data -> 'passport' -> 'data' -> '_address' ->> 'single_line_address', | ||
fb.user_data -> 'passport' -> 'data' -> '_address' ->> 'title' | ||
) AS address, | ||
(fb.user_data -> 'passport' -> 'data' -> '_address' ->> 'uprn') AS uprn, | ||
(fb.user_data -> 'passport' -> 'data' ->> 'proposal.projectType') AS project_type, | ||
(fb.user_data -> 'passport' -> 'data' ->> 'property.constraints.planning') AS intersecting_constraints, | ||
published_flow_node.data AS node_data | ||
FROM | ||
feedback fb | ||
LEFT JOIN | ||
flows f ON f.id = fb.flow_id | ||
LEFT JOIN | ||
teams t ON t.id = fb.team_id | ||
LEFT JOIN LATERAL | ||
( | ||
SELECT | ||
(published_flows.data -> fb.node_id) -> 'data' AS data | ||
FROM | ||
published_flows | ||
WHERE | ||
published_flows.flow_id = fb.flow_id | ||
AND published_flows.created_at < fb.created_at | ||
ORDER BY | ||
published_flows.created_at DESC | ||
LIMIT 1 | ||
) AS published_flow_node ON true; | ||
|
||
GRANT SELECT ON public.feedback_summary TO metabase_read_only; |
40 changes: 40 additions & 0 deletions
40
hasura.planx.uk/migrations/1715868696352_run_sql_migration/up.sql
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,40 @@ | ||
DROP VIEW "public"."feedback_summary"; | ||
|
||
CREATE OR REPLACE VIEW "public"."feedback_summary" AS | ||
SELECT | ||
fb.id AS feedback_id, | ||
t.slug AS team, | ||
f.slug AS service_slug, | ||
fb.created_at, | ||
fb.node_id, | ||
fb.device, | ||
fb.user_context, | ||
fb.user_comment, | ||
fb.feedback_type, | ||
fb.status, | ||
fb.node_type, | ||
fb.node_data, | ||
COALESCE( | ||
fb.node_data ->> 'title', | ||
fb.node_data ->> 'text', | ||
fb.node_data ->> 'flagSet' | ||
) AS node_title, | ||
fb.node_data ->> 'description' AS node_text, | ||
fb.node_data ->> 'info' AS help_text, | ||
fb.node_data ->> 'policyRef' AS help_sources, | ||
fb.node_data ->> 'howMeasured' AS help_definition, | ||
COALESCE( | ||
fb.user_data -> 'passport' -> 'data' -> '_address' ->> 'single_line_address', | ||
fb.user_data -> 'passport' -> 'data' -> '_address' ->> 'title' | ||
) AS address, | ||
(fb.user_data -> 'passport' -> 'data' -> '_address' ->> 'uprn') AS uprn, | ||
(fb.user_data -> 'passport' -> 'data' ->> 'proposal.projectType') AS project_type, | ||
(fb.user_data -> 'passport' -> 'data' ->> 'property.constraints.planning') AS intersecting_constraints | ||
FROM | ||
feedback fb | ||
LEFT JOIN | ||
flows f ON f.id = fb.flow_id | ||
LEFT JOIN | ||
teams t ON t.id = fb.team_id; | ||
|
||
GRANT SELECT ON public.feedback_summary TO metabase_read_only; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,70 @@ | ||
-- insert feedback overwriting conflicts | ||
CREATE TEMPORARY TABLE sync_feedback ( | ||
id integer, | ||
team_id integer, | ||
flow_id uuid, | ||
created_at timestamptz, | ||
node_id text, | ||
device jsonb, | ||
user_data jsonb, | ||
user_context text, | ||
user_comment text, | ||
feedback_type text, | ||
status text, | ||
node_type text, | ||
node_data jsonb | ||
); | ||
|
||
\copy sync_feedback FROM '/tmp/feedback.csv' WITH (FORMAT csv, DELIMITER ';'); | ||
|
||
INSERT INTO | ||
feedback ( | ||
id, | ||
team_id, | ||
flow_id, | ||
created_at, | ||
node_id, | ||
device, | ||
user_data, | ||
user_context, | ||
user_comment, | ||
feedback_type, | ||
status, | ||
node_type, | ||
node_data | ||
) | ||
SELECT | ||
id, | ||
team_id, | ||
flow_id, | ||
created_at, | ||
node_id, | ||
device, | ||
user_data, | ||
user_context, | ||
user_comment, | ||
feedback_type, | ||
status, | ||
node_type, | ||
node_data | ||
FROM | ||
sync_feedback ON CONFLICT (id) DO | ||
UPDATE | ||
SET | ||
id = EXCLUDED.id, | ||
team_id = EXCLUDED.team_id, | ||
flow_id = EXCLUDED.flow_id, | ||
created_at = EXCLUDED.created_at, | ||
node_id = EXCLUDED.node_id, | ||
device = EXCLUDED.device, | ||
user_data = EXCLUDED.user_data, | ||
user_context = EXCLUDED.user_context, | ||
user_comment = EXCLUDED.user_comment, | ||
feedback_type = EXCLUDED.feedback_type, | ||
status = EXCLUDED.status, | ||
node_type = EXCLUDED.node_type, | ||
node_data = EXCLUDED.node_data; | ||
SELECT | ||
setval('feedback_id_seq', max(id)) | ||
FROM | ||
feedback; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,8 +1,12 @@ | ||
-- Mandatory tables | ||
\include write/users.sql | ||
\include write/teams.sql | ||
\include write/flows.sql | ||
\include write/flow_document_templates.sql | ||
\include write/published_flows.sql | ||
\include write/team_members.sql | ||
\include write/team_integrations.sql | ||
\include write/team_themes.sql | ||
\include write/team_themes.sql | ||
|
||
-- Optional tables | ||
\include write/feedback.sql |