forked from MapComplete/MapComplete
Fix: fix #1844
This commit is contained in:
parent
5f967555eb
commit
e11442e100
4 changed files with 80 additions and 33 deletions
|
@ -672,6 +672,8 @@
|
||||||
"i_am_affiliated_explanation": "Check if you are an owner, creator, employee, …",
|
"i_am_affiliated_explanation": "Check if you are an owner, creator, employee, …",
|
||||||
"name_required": "A name is required in order to display and create reviews",
|
"name_required": "A name is required in order to display and create reviews",
|
||||||
"no_reviews_yet": "There are no reviews yet. Be the first to write one and help open data and the business!",
|
"no_reviews_yet": "There are no reviews yet. Be the first to write one and help open data and the business!",
|
||||||
|
"non_place_review": "One review is not about a place and is not shown here.",
|
||||||
|
"non_place_reviews": "{n} reviews are not about a place and are not shown here.",
|
||||||
"question": "How would you rate {title()}?",
|
"question": "How would you rate {title()}?",
|
||||||
"question_opinion": "How was your experience?",
|
"question_opinion": "How was your experience?",
|
||||||
"rate": "Rate {n} stars",
|
"rate": "Rate {n} stars",
|
||||||
|
@ -683,6 +685,7 @@
|
||||||
"save": "Save review",
|
"save": "Save review",
|
||||||
"saved": "Review saved. Thanks for sharing!",
|
"saved": "Review saved. Thanks for sharing!",
|
||||||
"saving_review": "Saving…",
|
"saving_review": "Saving…",
|
||||||
|
"see_all": "See all your reviews on mangrove.reviews",
|
||||||
"title": "{count} reviews",
|
"title": "{count} reviews",
|
||||||
"title_singular": "One review",
|
"title_singular": "One review",
|
||||||
"too_long": "At most {max} characters are allowed. Your review has {amount} characters.",
|
"too_long": "At most {max} characters are allowed. Your review has {amount} characters.",
|
||||||
|
|
|
@ -3,6 +3,7 @@ import { MangroveReviews, Review } from "mangrove-reviews-typescript"
|
||||||
import { Utils } from "../../Utils"
|
import { Utils } from "../../Utils"
|
||||||
import { Feature, Position } from "geojson"
|
import { Feature, Position } from "geojson"
|
||||||
import { GeoOperations } from "../GeoOperations"
|
import { GeoOperations } from "../GeoOperations"
|
||||||
|
import ScriptUtils from "../../../scripts/ScriptUtils"
|
||||||
|
|
||||||
export class MangroveIdentity {
|
export class MangroveIdentity {
|
||||||
private readonly keypair: Store<CryptoKeyPair>
|
private readonly keypair: Store<CryptoKeyPair>
|
||||||
|
@ -70,32 +71,53 @@ export class MangroveIdentity {
|
||||||
return this.key_id
|
return this.key_id
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private geoReviewsById: Store<(Review & { kid: string; signature: string })[]> =
|
||||||
|
undefined
|
||||||
|
|
||||||
|
public getGeoReviews(): Store<(Review & { kid: string, signature: string })[] | undefined> {
|
||||||
|
if (!this.geoReviewsById) {
|
||||||
|
const all = this.getAllReviews()
|
||||||
|
this.geoReviewsById = this.getAllReviews().mapD(reviews => reviews.filter(
|
||||||
|
review => {
|
||||||
|
try{
|
||||||
|
const subjectUrl = new URL(review.sub)
|
||||||
|
console.log(">>>", subjectUrl)
|
||||||
|
return subjectUrl.protocol === "geo:"
|
||||||
|
}catch (e) {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
))
|
||||||
|
}
|
||||||
|
return this.geoReviewsById
|
||||||
|
}
|
||||||
|
|
||||||
private allReviewsById: UIEventSource<(Review & { kid: string; signature: string })[]> =
|
private allReviewsById: UIEventSource<(Review & { kid: string; signature: string })[]> =
|
||||||
undefined
|
undefined
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets all reviews that are made for the current identity.
|
* Gets all reviews that are made for the current identity.
|
||||||
|
* The returned store will contain `undefined` if still loading
|
||||||
*/
|
*/
|
||||||
public getAllReviews(): Store<(Review & { kid: string; signature: string })[]> {
|
public getAllReviews(): Store<(Review & { kid: string; signature: string })[] | undefined> {
|
||||||
if (this.allReviewsById !== undefined) {
|
if (this.allReviewsById !== undefined) {
|
||||||
return this.allReviewsById
|
return this.allReviewsById
|
||||||
}
|
}
|
||||||
this.allReviewsById = new UIEventSource([])
|
this.allReviewsById = new UIEventSource(undefined)
|
||||||
this.key_id.map((pem) => {
|
this.key_id.map(async (pem) => {
|
||||||
if (pem === undefined) {
|
if (pem === undefined) {
|
||||||
return []
|
return []
|
||||||
}
|
}
|
||||||
MangroveReviews.getReviews({
|
const allReviews = await MangroveReviews.getReviews({
|
||||||
kid: pem,
|
kid: pem
|
||||||
}).then((allReviews) => {
|
})
|
||||||
this.allReviewsById.setData(
|
this.allReviewsById.setData(
|
||||||
allReviews.reviews.map((r) => ({
|
allReviews.reviews.map((r) => ({
|
||||||
...r,
|
...r,
|
||||||
...r.payload,
|
...r.payload
|
||||||
}))
|
}))
|
||||||
)
|
)
|
||||||
})
|
})
|
||||||
})
|
|
||||||
return this.allReviewsById
|
return this.allReviewsById
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -243,7 +265,7 @@ export default class FeatureReviews {
|
||||||
}
|
}
|
||||||
const r: Review = {
|
const r: Review = {
|
||||||
sub: this.subjectUri.data,
|
sub: this.subjectUri.data,
|
||||||
...review,
|
...review
|
||||||
}
|
}
|
||||||
const keypair: CryptoKeyPair = await this._identity.getKeypair()
|
const keypair: CryptoKeyPair = await this._identity.getKeypair()
|
||||||
const jwt = await MangroveReviews.signReview(keypair, r)
|
const jwt = await MangroveReviews.signReview(keypair, r)
|
||||||
|
@ -253,7 +275,7 @@ export default class FeatureReviews {
|
||||||
...r,
|
...r,
|
||||||
kid,
|
kid,
|
||||||
signature: jwt,
|
signature: jwt,
|
||||||
madeByLoggedInUser: new ImmutableStore(true),
|
madeByLoggedInUser: new ImmutableStore(true)
|
||||||
}
|
}
|
||||||
this._reviews.data.push(reviewWithKid)
|
this._reviews.data.push(reviewWithKid)
|
||||||
this._reviews.ping()
|
this._reviews.ping()
|
||||||
|
@ -301,7 +323,7 @@ export default class FeatureReviews {
|
||||||
signature: reviewData.signature,
|
signature: reviewData.signature,
|
||||||
madeByLoggedInUser: this._identity.getKeyId().map((user_key_id) => {
|
madeByLoggedInUser: this._identity.getKeyId().map((user_key_id) => {
|
||||||
return reviewData.kid === user_key_id
|
return reviewData.kid === user_key_id
|
||||||
}),
|
})
|
||||||
})
|
})
|
||||||
hasNew = true
|
hasNew = true
|
||||||
}
|
}
|
||||||
|
@ -322,7 +344,7 @@ export default class FeatureReviews {
|
||||||
// https://www.rfc-editor.org/rfc/rfc5870#section-3.4.2
|
// https://www.rfc-editor.org/rfc/rfc5870#section-3.4.2
|
||||||
// `u` stands for `uncertainty`, https://www.rfc-editor.org/rfc/rfc5870#section-3.4.3
|
// `u` stands for `uncertainty`, https://www.rfc-editor.org/rfc/rfc5870#section-3.4.3
|
||||||
const self = this
|
const self = this
|
||||||
return this._name.map(function (name) {
|
return this._name.map(function(name) {
|
||||||
let uri = `geo:${self._lat},${self._lon}?u=${Math.round(self._uncertainty)}`
|
let uri = `geo:${self._lat},${self._lon}?u=${Math.round(self._uncertainty)}`
|
||||||
if (name) {
|
if (name) {
|
||||||
uri += "&q=" + (dontEncodeName ? name : encodeURIComponent(name))
|
uri += "&q=" + (dontEncodeName ? name : encodeURIComponent(name))
|
||||||
|
|
|
@ -6,12 +6,15 @@
|
||||||
import LoginButton from "../Base/LoginButton.svelte"
|
import LoginButton from "../Base/LoginButton.svelte"
|
||||||
import SingleReview from "./SingleReview.svelte"
|
import SingleReview from "./SingleReview.svelte"
|
||||||
import Mangrove_logo from "../../assets/svg/Mangrove_logo.svelte"
|
import Mangrove_logo from "../../assets/svg/Mangrove_logo.svelte"
|
||||||
|
import Loading from "../Base/Loading.svelte"
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A panel showing all the reviews by the logged-in user
|
* A panel showing all the reviews by the logged-in user
|
||||||
*/
|
*/
|
||||||
export let state: SpecialVisualizationState
|
export let state: SpecialVisualizationState
|
||||||
let reviews = state.userRelatedState.mangroveIdentity.getAllReviews()
|
let allReviews = state.userRelatedState.mangroveIdentity.getAllReviews()
|
||||||
|
let reviews = state.userRelatedState.mangroveIdentity.getGeoReviews()
|
||||||
|
let kid = state.userRelatedState.mangroveIdentity.getKeyId()
|
||||||
const t = Translations.t.reviews
|
const t = Translations.t.reviews
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
@ -22,8 +25,11 @@
|
||||||
</LoginButton>
|
</LoginButton>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
{#if $reviews === undefined}
|
||||||
|
<Loading />
|
||||||
|
{:else}
|
||||||
{#if $reviews?.length > 0}
|
{#if $reviews?.length > 0}
|
||||||
<div class="flex flex-col" on:keypress={(e) => console.log("Got keypress", e)}>
|
<div class="flex flex-col gap-y-1" on:keypress={(e) => console.log("Got keypress", e)}>
|
||||||
{#each $reviews as review (review.sub)}
|
{#each $reviews as review (review.sub)}
|
||||||
<SingleReview {review} showSub={true} {state} />
|
<SingleReview {review} showSub={true} {state} />
|
||||||
{/each}
|
{/each}
|
||||||
|
@ -31,6 +37,21 @@
|
||||||
{:else}
|
{:else}
|
||||||
<Tr t={t.your_reviews_empty} />
|
<Tr t={t.your_reviews_empty} />
|
||||||
{/if}
|
{/if}
|
||||||
|
|
||||||
|
{#if $allReviews?.length > $reviews?.length}
|
||||||
|
{#if $allReviews?.length - $reviews?.length === 1}
|
||||||
|
<Tr t={t.non_place_review} />
|
||||||
|
{:else}
|
||||||
|
<Tr t={t.non_place_reviews.Subs({n:$allReviews?.length - $reviews?.length })} />
|
||||||
|
{/if}
|
||||||
|
<a target="_blank"
|
||||||
|
class="link-underline"
|
||||||
|
rel="noopener nofollow"
|
||||||
|
href={`https://mangrove.reviews/list?kid=${encodeURIComponent($kid)}`}
|
||||||
|
>
|
||||||
|
<Tr t={t.see_all} />
|
||||||
|
</a>
|
||||||
|
{/if}
|
||||||
<a
|
<a
|
||||||
class="link-underline"
|
class="link-underline"
|
||||||
href="https://github.com/pietervdvn/MapComplete/issues/1782"
|
href="https://github.com/pietervdvn/MapComplete/issues/1782"
|
||||||
|
@ -39,6 +60,7 @@
|
||||||
>
|
>
|
||||||
<Tr t={t.reviews_bug} />
|
<Tr t={t.reviews_bug} />
|
||||||
</a>
|
</a>
|
||||||
|
{/if}
|
||||||
<div class="flex justify-end">
|
<div class="flex justify-end">
|
||||||
<Mangrove_logo class="h-12 w-12 shrink-0 p-1" />
|
<Mangrove_logo class="h-12 w-12 shrink-0 p-1" />
|
||||||
<Tr cls="text-sm subtle" t={t.attribution} />
|
<Tr cls="text-sm subtle" t={t.attribution} />
|
||||||
|
|
Loading…
Reference in a new issue