diff --git a/hasura/metadata/databases/default/tables/public_producers_list.yaml b/hasura/metadata/databases/default/tables/public_producers_list.yaml index 8162fc57..5ad3726a 100644 --- a/hasura/metadata/databases/default/tables/public_producers_list.yaml +++ b/hasura/metadata/databases/default/tables/public_producers_list.yaml @@ -4,18 +4,20 @@ table: select_permissions: - permission: columns: - - average - - bpjson - - candidate_name - - community - - development - - general_info - - infrastructure - owner - - ratings_cntr + - bpjson - system + - candidate_name - total_votes + - eden_average + - eden_ratings_cntr + - average - transparency + - infrastructure - trustiness + - community + - development + - ratings_cntr + - general_info filter: {} role: anonymous diff --git a/hasura/migrations/default/1630079306181_run_sql_migration/down.sql b/hasura/migrations/default/1630079306181_run_sql_migration/down.sql new file mode 100644 index 00000000..4231e960 --- /dev/null +++ b/hasura/migrations/default/1630079306181_run_sql_migration/down.sql @@ -0,0 +1,19 @@ +-- Could not auto-generate a down migration. +-- Please write an appropriate down migration for the SQL below: +-- CREATE OR REPLACE VIEW "public"."producers_list" AS +-- SELECT producers.owner, +-- producers.bpjson, +-- producers.system, +-- ((producers.bpjson -> 'org'::text) ->> 'candidate_name'::text) AS candidate_name, +-- (producers.system ->> 'total_votes'::text) AS total_votes, +-- ratings_stats.average, +-- ratings_stats.transparency, +-- ratings_stats.infrastructure, +-- ratings_stats.trustiness, +-- ratings_stats.community, +-- ratings_stats.development, +-- ratings_stats.ratings_cntr, +-- producers.general_info +-- FROM (producers +-- FULL JOIN ratings_stats ON (((ratings_stats.bp)::text = producers.owner)) +-- FULL JOIN eden_ratings_stats ON eden_ratings_stats.bp = producers.owner); diff --git a/hasura/migrations/default/1630079306181_run_sql_migration/up.sql b/hasura/migrations/default/1630079306181_run_sql_migration/up.sql new file mode 100644 index 00000000..23a17d4f --- /dev/null +++ b/hasura/migrations/default/1630079306181_run_sql_migration/up.sql @@ -0,0 +1,17 @@ +CREATE OR REPLACE VIEW "public"."producers_list" AS + SELECT producers.owner, + producers.bpjson, + producers.system, + ((producers.bpjson -> 'org'::text) ->> 'candidate_name'::text) AS candidate_name, + (producers.system ->> 'total_votes'::text) AS total_votes, + ratings_stats.average, + ratings_stats.transparency, + ratings_stats.infrastructure, + ratings_stats.trustiness, + ratings_stats.community, + ratings_stats.development, + ratings_stats.ratings_cntr, + producers.general_info + FROM (producers + FULL JOIN ratings_stats ON (((ratings_stats.bp)::text = producers.owner)) + FULL JOIN eden_ratings_stats ON eden_ratings_stats.bp = producers.owner); diff --git a/hasura/migrations/default/1630081052611_run_sql_migration/down.sql b/hasura/migrations/default/1630081052611_run_sql_migration/down.sql new file mode 100644 index 00000000..be9cf87c --- /dev/null +++ b/hasura/migrations/default/1630081052611_run_sql_migration/down.sql @@ -0,0 +1,3 @@ +-- Could not auto-generate a down migration. +-- Please write an appropriate down migration for the SQL below: +-- drop view "public"."producers_list"; diff --git a/hasura/migrations/default/1630081052611_run_sql_migration/up.sql b/hasura/migrations/default/1630081052611_run_sql_migration/up.sql new file mode 100644 index 00000000..17d262ff --- /dev/null +++ b/hasura/migrations/default/1630081052611_run_sql_migration/up.sql @@ -0,0 +1 @@ +drop view "public"."producers_list"; diff --git a/hasura/migrations/default/1630081060538_run_sql_migration/down.sql b/hasura/migrations/default/1630081060538_run_sql_migration/down.sql new file mode 100644 index 00000000..c0ad8e15 --- /dev/null +++ b/hasura/migrations/default/1630081060538_run_sql_migration/down.sql @@ -0,0 +1,21 @@ +-- Could not auto-generate a down migration. +-- Please write an appropriate down migration for the SQL below: +-- CREATE OR REPLACE VIEW "public"."producers_list" AS +-- SELECT producers.owner, +-- producers.bpjson, +-- producers.system, +-- ((producers.bpjson -> 'org'::text) ->> 'candidate_name'::text) AS candidate_name, +-- (producers.system ->> 'total_votes'::text) AS total_votes, +-- eden_ratings_stats.average AS eden_average, +-- eden_ratings_stats.ratings_cntr AS eden_ratings_cntr, +-- ratings_stats.average, +-- ratings_stats.transparency, +-- ratings_stats.infrastructure, +-- ratings_stats.trustiness, +-- ratings_stats.community, +-- ratings_stats.development, +-- ratings_stats.ratings_cntr, +-- producers.general_info +-- FROM (producers +-- FULL JOIN ratings_stats ON (((ratings_stats.bp)::text = producers.owner)) +-- FULL JOIN eden_ratings_stats ON ((eden_ratings_stats.bp)::text = producers.owner)); diff --git a/hasura/migrations/default/1630081060538_run_sql_migration/up.sql b/hasura/migrations/default/1630081060538_run_sql_migration/up.sql new file mode 100644 index 00000000..eacbcf6f --- /dev/null +++ b/hasura/migrations/default/1630081060538_run_sql_migration/up.sql @@ -0,0 +1,19 @@ +CREATE OR REPLACE VIEW "public"."producers_list" AS + SELECT producers.owner, + producers.bpjson, + producers.system, + ((producers.bpjson -> 'org'::text) ->> 'candidate_name'::text) AS candidate_name, + (producers.system ->> 'total_votes'::text) AS total_votes, + eden_ratings_stats.average AS eden_average, + eden_ratings_stats.ratings_cntr AS eden_ratings_cntr, + ratings_stats.average, + ratings_stats.transparency, + ratings_stats.infrastructure, + ratings_stats.trustiness, + ratings_stats.community, + ratings_stats.development, + ratings_stats.ratings_cntr, + producers.general_info + FROM (producers + FULL JOIN ratings_stats ON (((ratings_stats.bp)::text = producers.owner)) + FULL JOIN eden_ratings_stats ON ((eden_ratings_stats.bp)::text = producers.owner)); diff --git a/webapp/src/components/card/index.js b/webapp/src/components/card/index.js index 11cb453c..0e31d5e7 100644 --- a/webapp/src/components/card/index.js +++ b/webapp/src/components/card/index.js @@ -170,7 +170,7 @@ const CardData = ({ {...props} ref={ref} state={{ owner: owner }} - to={`/block-producers/${owner}/rate`} + to={`/${pathLink}/${owner}`} /> ))} className={classes.btnRate} diff --git a/webapp/src/language/en.json b/webapp/src/language/en.json index a7c93f55..62476c25 100644 --- a/webapp/src/language/en.json +++ b/webapp/src/language/en.json @@ -14,8 +14,8 @@ "btnVoteBPs": "Vote", "clearSelection": "Clear selection", "loadMore": "Load more", - "view": "View", - "remove": "Remove", + "view": "More info", + "remove": "Remove vote", "addToVote": "Add to vote", "selected": "Selected", "details": "Details", @@ -81,6 +81,7 @@ "alphabetical": "Alphabetical", "ratings": "Number of Ratings", "generalRate": "Top Rated General", + "edenRate": "Top Rated Eden", "infrastructure": "Top Rated Infrastructure", "community": "Top Rated Community", "trustiness": "Top Rated Trustiness", diff --git a/webapp/src/language/es.json b/webapp/src/language/es.json index 2752de21..76576a2e 100644 --- a/webapp/src/language/es.json +++ b/webapp/src/language/es.json @@ -14,7 +14,7 @@ "btnVoteBPs": "Votar", "clearSelection": "Borrar selección", "loadMore": "Cargar más", - "view": "Ver", + "view": "Más información", "remove": "Remover", "addToVote": "Agregar para votar", "selected": "Seleccionado", @@ -81,6 +81,7 @@ "alphabetical": "Alfabético", "ratings": "Número de Evaluaciones", "generalRate": "Mayor Calificación General", + "edenRate": "Mayor Calificación Eden", "infrastructure": "Mayor Calificación Infraestructura", "community": "Mayor Calificación Comunidad", "trustiness": "Mayor Calificación Confianza", diff --git a/webapp/src/models/BlockProducer/blockProducers.js b/webapp/src/models/BlockProducer/blockProducers.js index c1428885..648a68c6 100644 --- a/webapp/src/models/BlockProducer/blockProducers.js +++ b/webapp/src/models/BlockProducer/blockProducers.js @@ -196,7 +196,7 @@ const Proxies = { fetchPolicy: 'network-only' }) - if (edenRatings.length > 0) this.addEdenRate(edenRatings[0]) + this.addEdenRate(edenRatings.length > 0 ? edenRatings[0] : null) dispatch.isLoading.storeIsContentLoading(false) } catch (error) { diff --git a/webapp/src/routes/block-producers/index.js b/webapp/src/routes/block-producers/index.js index 36f0d6cf..7a1a8c6e 100644 --- a/webapp/src/routes/block-producers/index.js +++ b/webapp/src/routes/block-producers/index.js @@ -276,6 +276,7 @@ export default AllBps export const blockProducersDrawer = [ { value: 'alphabetical' }, { value: 'generalRate' }, + { value: 'edenRate' }, { value: 'infrastructure' }, { value: 'community' }, { value: 'trustiness' }, diff --git a/webapp/src/routes/proxies/index.js b/webapp/src/routes/proxies/index.js index faf5e6c5..b8c51ae0 100644 --- a/webapp/src/routes/proxies/index.js +++ b/webapp/src/routes/proxies/index.js @@ -217,7 +217,6 @@ const AllProxies = ({ ual }) => { owner={_get(proxy, 'owner')} title={_get(proxy, 'name')} useRateButton={false} - buttonLabel={t('view')} pathLink='proxies' showOptions={false} /> diff --git a/webapp/src/routes/proxies/proxy-profile.js b/webapp/src/routes/proxies/proxy-profile.js index 5e3eab27..d08de354 100644 --- a/webapp/src/routes/proxies/proxy-profile.js +++ b/webapp/src/routes/proxies/proxy-profile.js @@ -263,7 +263,7 @@ const ProxyProfile = ({ account, ual, ...props }) => { {!isMobile && ( - + {} } = {}) => { transparency ratings_cntr general_info + eden_average + eden_ratings_cntr } } `, @@ -68,7 +70,6 @@ export const getAllBPs = ({ nameFilter = null, setBPs = () => {} } = {}) => { const votesInEos = calculateEosFromVotes( _get(bp, 'system.total_votes', 0) ) - return { ...bp, system: { diff --git a/webapp/src/utils/sortedBy.js b/webapp/src/utils/sortedBy.js index 3aa91cf5..dab2b0b5 100644 --- a/webapp/src/utils/sortedBy.js +++ b/webapp/src/utils/sortedBy.js @@ -30,6 +30,12 @@ export default (sortBy, blockProducers) => { return (blockProducers || []).sort((a, b) => _sortValues(a, b, 'average')) } + case 'edenRate': { + return (blockProducers || []).sort((a, b) => + _sortValues(a, b, 'eden_average') + ) + } + case 'infrastructure': { return (blockProducers || []).sort((a, b) => _sortValues(a, b, 'system.parameters.infrastructure')