Skip to content

Commit

Permalink
Fixed country flag and circuit image for UAE (#24)
Browse files Browse the repository at this point in the history
  • Loading branch information
marcokreeft87 authored Nov 14, 2022
1 parent f7e0ec2 commit 8413316
Show file tree
Hide file tree
Showing 9 changed files with 42 additions and 13 deletions.
8 changes: 4 additions & 4 deletions formulaone-card.js

Large diffs are not rendered by default.

Binary file modified formulaone-card.js.gz
Binary file not shown.
4 changes: 2 additions & 2 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "formulaone-card",
"version": "0.1.3",
"version": "0.1.4",
"description": "Frontend card for hass-formulaoneapi",
"main": "index.js",
"scripts": {
Expand Down
5 changes: 3 additions & 2 deletions src/cards/last-result.ts
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import { HomeAssistant } from "custom-card-helpers";
import { html, HTMLTemplateResult } from "lit-html";
import { FormulaOneCardConfig, Race, Result } from "../types/formulaone-card-types";
import { getCountryFlagUrl, getDriverName } from "../utils";
import { getCircuitName, getCountryFlagUrl, getDriverName } from "../utils";
import { BaseCard } from "./base-card";

export default class LastResult extends BaseCard {
Expand All @@ -26,7 +26,8 @@ export default class LastResult extends BaseCard {

const data = this.sensor.data as Race;
const countryDashed = data.Circuit.Location.country.replace(" ","-");
const imageHtml = html`<img width="100%" src="https://www.formula1.com/content/dam/fom-website/2018-redesign-assets/Circuit%20maps%2016x9/${countryDashed}_Circuit.png.transform/7col/image.png">`;
const circuitName = getCircuitName(countryDashed);
const imageHtml = html`<img width="100%" src="https://www.formula1.com/content/dam/fom-website/2018-redesign-assets/Circuit%20maps%2016x9/${circuitName}_Circuit.png.transform/7col/image.png">`;
const imageWithLinkHtml = this.config.image_clickable ? html`<a target="_new" href="${data.Circuit.url}">${imageHtml}</a>` : imageHtml;

return html`<h2><img height="25" src="${getCountryFlagUrl(countryDashed)}">&nbsp; ${data.round} : ${data.raceName}</h2>${imageWithLinkHtml}<br> `
Expand Down
8 changes: 5 additions & 3 deletions src/cards/next-race.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import { html, HTMLTemplateResult } from "lit-html";
import { formatDateNumeric } from "../lib/format_date";
import { formatDateTimeRaceInfo } from "../lib/format_date_time";
import { FormulaOneCardConfig, Race } from "../types/formulaone-card-types";
import { getCountryFlagUrl } from "../utils";
import { getCircuitName, getCountryFlagUrl } from "../utils";
import { BaseCard } from "./base-card";

export default class NextRace extends BaseCard {
Expand All @@ -20,8 +20,10 @@ export default class NextRace extends BaseCard {

renderHeader(): HTMLTemplateResult {

const countryDashed = this.next_race.Circuit.Location.country.replace(" ","-");
const imageHtml = html`<img width="100%" src="https://www.formula1.com/content/dam/fom-website/2018-redesign-assets/Circuit%20maps%2016x9/${countryDashed}_Circuit.png.transform/7col/image.png">`;
const countryDashed = this.next_race.Circuit.Location.country.replace(" ","-")
const circuitName = getCircuitName(countryDashed);

const imageHtml = html`<img width="100%" src="https://www.formula1.com/content/dam/fom-website/2018-redesign-assets/Circuit%20maps%2016x9/${circuitName}_Circuit.png.transform/7col/image.png">`;
const imageWithLinkHtml = this.config.image_clickable ? html`<a target="_new" href="${this.next_race.Circuit.url}">${imageHtml}</a>` : imageHtml;

return html`<h2><img height="25" src="${getCountryFlagUrl(countryDashed)}">&nbsp; ${this.next_race.round} : ${this.next_race.raceName}</h2>${imageWithLinkHtml}<br> `
Expand Down
14 changes: 13 additions & 1 deletion src/utils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ export const checkConfig = (config: FormulaOneCardConfig) => {
};

export const getCountryFlagUrl = (countryDashed: string) => {
const exceptions = [{ countryDashed: 'USA', name: 'United-States-of-America'}];
const exceptions = [{ countryDashed: 'USA', name: 'United-States-of-America'}, { countryDashed: 'UAE', name: 'United-Arab-Emirates'}];

const exception = exceptions.filter(exception => exception.countryDashed == countryDashed);
if(exception.length > 0)
Expand All @@ -36,6 +36,18 @@ export const getCountryFlagUrl = (countryDashed: string) => {
return `https://www.countries-ofthe-world.com/flags-normal/flag-of-${countryDashed}.png`;
}

export const getCircuitName = (circuitName: string) => {
const exceptions = [{ countryDashed: 'UAE', name: 'Abu_Dhabi'}];

const exception = exceptions.filter(exception => exception.countryDashed == circuitName);
if(exception.length > 0)
{
circuitName = exception[0].name;
}

return circuitName;
}

export const getDriverName = (driver: Driver, config: FormulaOneCardConfig) => {
const permanentNumber = driver.code == 'VER' ? 1 : driver.permanentNumber;
return `${driver.givenName} ${driver.familyName}${(config.show_carnumber ? ` #${permanentNumber}` : '')}`;
Expand Down
11 changes: 11 additions & 0 deletions tests/utils/getCircuitName.test.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
import { getCircuitName } from '../../src/utils';

describe('Testing util file function getCircuitName', () => {
test('Passing Japan should return expected circuit name', () => {
expect(getCircuitName('Japan')).toBe('Japan')
}),
test('Passing UAE should return expected circuit name', () => {
expect(getCircuitName('UAE')).toBe('Abu_Dhabi')
})
})

3 changes: 3 additions & 0 deletions tests/utils/getCountryFlagUrl.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,9 @@ describe('Testing util file function getCountryFlagUrl', () => {
test('Passing USA should return expected flag url', () => {
expect(getCountryFlagUrl('USA')).toBe('https://www.countries-ofthe-world.com/flags-normal/flag-of-United-States-of-America.png')
}),
test('Passing UAE should return expected flag url', () => {
expect(getCountryFlagUrl('UAE')).toBe('https://www.countries-ofthe-world.com/flags-normal/flag-of-United-Arab-Emirates.png')
}),
test('Passing Saudi Arabia should return expected flag url', () => {
expect(getCountryFlagUrl('Saudi-Arabia')).toBe('https://www.countries-ofthe-world.com/flags-normal/flag-of-Saudi-Arabia.png')
})
Expand Down

0 comments on commit 8413316

Please sign in to comment.