diff --git a/Logic/Web/MangroveReviews.ts b/Logic/Web/MangroveReviews.ts index 5990c8792..453aa7148 100644 --- a/Logic/Web/MangroveReviews.ts +++ b/Logic/Web/MangroveReviews.ts @@ -5,6 +5,7 @@ import {Review} from "./Review"; export class MangroveIdentity { private readonly _mangroveIdentity: UIEventSource; public keypair: any = undefined; + public readonly kid: UIEventSource = new UIEventSource(undefined); constructor(mangroveIdentity: UIEventSource) { const self = this; @@ -13,10 +14,12 @@ export class MangroveIdentity { if (str === undefined || str === "") { return; } - console.log("JWK ", JSON.parse(str)); mangrove.jwkToKeypair(JSON.parse(str)).then(keypair => { self.keypair = keypair; - console.log("Identity loaded") + mangrove.publicToPem(keypair.publicKey).then(pem => { + console.log("Identity loaded") + self.kid.setData(pem); + }) }) }) if ((mangroveIdentity.data ?? "") === "") { @@ -117,9 +120,10 @@ export default class MangroveReviews { const reviewsByUser = []; for (const review of data.reviews) { const r = review.payload; - console.log("PublicKey is ",self._mangroveIdentity.keypair, "reviews is",review.signature); - const byUser = self._mangroveIdentity.keypair.publicKey === review.signature; - console.log("IS SAME: ", byUser); + + + console.log("PublicKey is ", self._mangroveIdentity.kid.data, "reviews.kid is", review.kid); + const byUser = self._mangroveIdentity.kid.map(data => data === review.signature); const rev: Review = { made_by_user: byUser, date: new Date(r.iat * 1000), @@ -133,7 +137,7 @@ export default class MangroveReviews { (rev.made_by_user ? reviewsByUser : reviews).push(rev); } - self._reviews.setData(reviews) + self._reviews.setData(reviewsByUser.concat(reviews)) } ); return this._reviews; diff --git a/Logic/Web/Review.ts b/Logic/Web/Review.ts index 8c037dd25..777330e44 100644 --- a/Logic/Web/Review.ts +++ b/Logic/Web/Review.ts @@ -1,3 +1,5 @@ +import {UIEventSource} from "../UIEventSource"; + export interface Review { comment?: string, author: string, @@ -7,5 +9,5 @@ export interface Review { /** * True if the current logged in user is the creator of this comment */ - made_by_user: boolean + made_by_user: UIEventSource } \ No newline at end of file diff --git a/UI/Reviews/ReviewElement.ts b/UI/Reviews/ReviewElement.ts index 2ed01bdc6..884757baa 100644 --- a/UI/Reviews/ReviewElement.ts +++ b/UI/Reviews/ReviewElement.ts @@ -4,10 +4,9 @@ import {UIEventSource} from "../../Logic/UIEventSource"; import {Review} from "../../Logic/Web/Review"; import {UIElement} from "../UIElement"; -import {Utils} from "../../Utils"; import Combine from "../Base/Combine"; -import {FixedUiElement} from "../Base/FixedUiElement"; import Translations from "../i18n/Translations"; +import SingleReview from "./SingleReview"; export default class ReviewElement extends UIElement { private readonly _reviews: UIEventSource; @@ -17,37 +16,25 @@ export default class ReviewElement extends UIElement { constructor(subject: string, reviews: UIEventSource, middleElement: UIElement) { super(reviews); this._middleElement = middleElement; - if(reviews === undefined){ + if (reviews === undefined) { throw "No reviews UIEVentsource Given!" } this._reviews = reviews; this._subject = subject; } - InnerRender(): string { + - function genStars(rating: number) { - if(rating === undefined){ - return Translations.t.reviews.no_rating; - } - if(rating < 10){ - rating = 10; - } - const scoreTen = Math.round(rating / 10); - return new Combine([ - "".repeat(Math.floor(scoreTen / 2)), - scoreTen % 2 == 1 ? "" : "" - ]) - } + InnerRender(): string { const elements = []; const revs = this._reviews.data; - revs.sort((a,b) => (b.date.getTime() - a.date.getTime())); // Sort with most recent first + revs.sort((a, b) => (b.date.getTime() - a.date.getTime())); // Sort with most recent first const avg = (revs.map(review => review.rating).reduce((a, b) => a + b, 0) / revs.length); elements.push( new Combine([ - genStars(avg).SetClass("stars"), - ``, + SingleReview.GenStars(avg).SetClass("stars"), + ``, Translations.t.reviews.title .Subs({count: "" + revs.length}), "" @@ -57,29 +44,7 @@ export default class ReviewElement extends UIElement { elements.push(this._middleElement); - elements.push(...revs.map(review => { - const d = review.date; - return new Combine( - [ - new Combine([ - genStars(review.rating) - .SetClass("review-rating"), - new FixedUiElement(review.comment).SetClass("review-comment") - ]).SetClass("review-stars-comment"), - - new Combine([ - new Combine([ - - new FixedUiElement(review.author).SetClass("review-author"), - review.affiliated ? Translations.t.reviews.affiliated_reviewer_warning : "", - ]).SetStyle("margin-right: 0.5em"), - new FixedUiElement(`${d.getFullYear()}-${Utils.TwoDigits(d.getMonth() + 1)}-${Utils.TwoDigits(d.getDate())} ${Utils.TwoDigits(d.getHours())}:${Utils.TwoDigits(d.getMinutes())}`) - .SetClass("review-date") - ]).SetClass("review-author-date") - - ] - ).SetClass("review-element") - })); + elements.push(...revs.map(review => new SingleReview(review))); elements.push( new Combine([ Translations.t.reviews.attribution, diff --git a/UI/Reviews/ReviewForm.ts b/UI/Reviews/ReviewForm.ts index 4f15a1d4c..9aa1f67da 100644 --- a/UI/Reviews/ReviewForm.ts +++ b/UI/Reviews/ReviewForm.ts @@ -27,7 +27,7 @@ export default class ReviewForm extends InputElement { this.userDetails = userDetails; const t = Translations.t.reviews; this._value = new UIEventSource({ - made_by_user: false, + made_by_user: new UIEventSource(true), rating: undefined, comment: undefined, author: userDetails.data.name, diff --git a/UI/Reviews/ReviewPanel.ts b/UI/Reviews/ReviewPanel.ts deleted file mode 100644 index 9ad64b707..000000000 --- a/UI/Reviews/ReviewPanel.ts +++ /dev/null @@ -1,11 +0,0 @@ -import {UIElement} from "../UIElement"; - -export default class ReviewPanel extends UIElement { - - - - InnerRender(): string { - return ""; - } - -} \ No newline at end of file diff --git a/UI/Reviews/SingleReview.ts b/UI/Reviews/SingleReview.ts new file mode 100644 index 000000000..44573631a --- /dev/null +++ b/UI/Reviews/SingleReview.ts @@ -0,0 +1,59 @@ +import {UIElement} from "../UIElement"; +import {Review} from "../../Logic/Web/Review"; +import Combine from "../Base/Combine"; +import {FixedUiElement} from "../Base/FixedUiElement"; +import Translations from "../i18n/Translations"; +import {Utils} from "../../Utils"; +import ReviewElement from "./ReviewElement"; + +export default class SingleReview extends UIElement{ + private _review: Review; + constructor(review: Review) { + super(review.made_by_user); + this._review = review; + + } + public static GenStars(rating: number): UIElement { + if (rating === undefined) { + return Translations.t.reviews.no_rating; + } + if (rating < 10) { + rating = 10; + } + const scoreTen = Math.round(rating / 10); + return new Combine([ + "".repeat(Math.floor(scoreTen / 2)), + scoreTen % 2 == 1 ? "" : "" + ]) + } + InnerRender(): string { + const d = this._review.date; + let review = this._review; + const el= new Combine( + [ + new Combine([ + SingleReview.GenStars(review.rating) + .SetClass("review-rating"), + new FixedUiElement(review.comment).SetClass("review-comment") + ]).SetClass("review-stars-comment"), + + new Combine([ + new Combine([ + + new FixedUiElement(review.author).SetClass("review-author"), + review.affiliated ? Translations.t.reviews.affiliated_reviewer_warning : "", + ]).SetStyle("margin-right: 0.5em"), + new FixedUiElement(`${d.getFullYear()}-${Utils.TwoDigits(d.getMonth() + 1)}-${Utils.TwoDigits(d.getDate())} ${Utils.TwoDigits(d.getHours())}:${Utils.TwoDigits(d.getMinutes())}`) + .SetClass("review-date") + ]).SetClass("review-author-date") + + ] + ); + el.SetClass("review-element"); + if(review.made_by_user){ + el.SetClass("review-by-current-user") + } + return el.Render(); + } + +} \ No newline at end of file diff --git a/css/ReviewElement.css b/css/ReviewElement.css index 7e04f34b7..f72f58228 100644 --- a/css/ReviewElement.css +++ b/css/ReviewElement.css @@ -23,6 +23,10 @@ height: 1em; } +.review-by-current-user { + border: 5px solid var(--catch-detail-color); +} + .review-rating { display: flex; flex-direction: row;