Skip to content

Commit

Permalink
Merge branch 'permanent-configuration' into cm/duplicate-id-edge-case
Browse files Browse the repository at this point in the history
  • Loading branch information
cmaddox5 committed Apr 25, 2024
2 parents d61a24a + 32c16aa commit ee0a66e
Show file tree
Hide file tree
Showing 58 changed files with 347 additions and 473 deletions.
2 changes: 0 additions & 2 deletions .github/dependabot.yml
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,5 @@ updates:
time: "10:00"
open-pull-requests-limit: 5
ignore:
- dependency-name: "phoenix"
- dependency-name: "phoenix_html"
- dependency-name: "*"
update-types: ["version-update:semver-minor"]
94 changes: 45 additions & 49 deletions assets/.eslintrc.js
Original file line number Diff line number Diff line change
@@ -1,52 +1,48 @@
module.exports = {
root: true,
parser: "@typescript-eslint/parser",
plugins: [
"@typescript-eslint",
"react",
"jsx-a11y",
],
extends: [
"eslint:recommended",
"plugin:@typescript-eslint/recommended",
"plugin:react/recommended",
"plugin:jsx-a11y/recommended",
],
"settings": {
"react": {
"version": "detect",
},
root: true,
parser: "@typescript-eslint/parser",
plugins: ["@typescript-eslint", "react", "jsx-a11y"],
extends: [
"eslint:recommended",
"plugin:@typescript-eslint/recommended",
"plugin:react/recommended",
"plugin:jsx-a11y/recommended",
],
settings: {
react: {
version: "detect",
},
"parserOptions": {
"ecmaFeatures": {
"jsx": true,
},
},
parserOptions: {
ecmaFeatures: {
jsx: true,
},
"reportUnusedDisableDirectives": true,
"rules": {
"no-console": 0,
"prefer-rest-params": "off",
"@typescript-eslint/ban-ts-comment": "off",
"@typescript-eslint/no-explicit-any": "off",
"@typescript-eslint/no-unused-vars": [
"error",
{
"argsIgnorePattern": "^_.*",
"varsIgnorePattern": "^_.*",
"destructuredArrayIgnorePattern": "^_.*",
}
],
"react/display-name": "off",
"react/function-component-definition": [
"error",
{
"namedComponents": "arrow-function",
"unnamedComponents": "arrow-function",
},
],
"react/hook-use-state": "error",
"react/no-danger": "error",
"jsx-a11y/no-static-element-interactions": "off",
"jsx-a11y/click-events-have-key-events": "off"
}
};
},
reportUnusedDisableDirectives: true,
rules: {
"no-console": 0,
"prefer-rest-params": "off",
"@typescript-eslint/ban-ts-comment": "off",
"@typescript-eslint/no-explicit-any": "off",
"@typescript-eslint/no-unused-vars": [
"error",
{
argsIgnorePattern: "^_.*",
varsIgnorePattern: "^_.*",
destructuredArrayIgnorePattern: "^_.*",
},
],
"react/display-name": "off",
"react/function-component-definition": [
"error",
{
namedComponents: "arrow-function",
unnamedComponents: "arrow-function",
},
],
"react/hook-use-state": "error",
"react/no-danger": "error",
"jsx-a11y/no-static-element-interactions": "off",
"jsx-a11y/click-events-have-key-events": "off",
},
};
2 changes: 2 additions & 0 deletions assets/css/dashboard/configure-screens-workflow-page.scss
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,8 @@
td,
th {
padding: 10px 24px;
color: $text-primary;
background-color: transparent;
}

.screen-id {
Expand Down
2 changes: 1 addition & 1 deletion assets/index.d.ts
Original file line number Diff line number Diff line change
@@ -1,3 +1,3 @@
declare module "*.png";
declare module "*.jpg";
declare module '*.svg';
declare module "*.svg";
18 changes: 9 additions & 9 deletions assets/js/app.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -6,13 +6,6 @@ import "../css/app.scss";
// webpack automatically bundles all modules in your
// entry points. Those entry points can be configured
// in "webpack.config.js".
//
// Import deps with the dep name or local files with a relative path, for example:
//
// import {Socket} from "phoenix"
// import socket from "./socket"
//
import "phoenix_html";

import "regenerator-runtime/runtime";

Expand All @@ -21,7 +14,7 @@ import ReactDOM from "react-dom";

import App from "./components/App";
import * as Sentry from "@sentry/react";
import * as FullStory from "@fullstory/browser";
import { FullStory, init as initFullStory } from "@fullstory/browser";

const environment = document
.querySelector("meta[name=environment-name]")
Expand Down Expand Up @@ -49,7 +42,14 @@ const fullstoryOrgId = document
?.getAttribute("content");

if (fullstoryOrgId) {
FullStory.init({ orgId: fullstoryOrgId, recordCrossDomainIFrames: true });
initFullStory({ orgId: fullstoryOrgId, recordCrossDomainIFrames: true });

if (username) {
FullStory("setIdentity", {
uid: username,
properties: { displayName: username },
});
}
}

ReactDOM.render(<App />, document.getElementById("app"));
8 changes: 4 additions & 4 deletions assets/js/components/App.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -4,20 +4,20 @@ import { ScreenplayProvider } from "../hooks/useScreenplayContext";
import GlEinkWorkflow from "./Dashboard/PermanentConfiguration/Workflows/GlEink/GlEinkWorkflow";

const OutfrontTakeoverTool = React.lazy(
() => import("./OutfrontTakeoverTool/OutfrontTakeoverTool")
() => import("./OutfrontTakeoverTool/OutfrontTakeoverTool"),
);
const Dashboard = React.lazy(() => import("./Dashboard/Dashboard"));
const PlacesPage = React.lazy(() => import("./Dashboard/PlacesPage"));
const AlertsPage = React.lazy(() => import("./Dashboard/AlertsPage"));
const AlertDetails = React.lazy(() => import("./Dashboard/AlertDetails"));
const PendingScreensPage = React.lazy(
() => import("./Dashboard/PendingScreensPage")
() => import("./Dashboard/PendingScreensPage"),
);
const ConfigureScreensPage = React.lazy(
() => import("./Dashboard/PermanentConfiguration/ConfigureScreensPage")
() => import("./Dashboard/PermanentConfiguration/ConfigureScreensPage"),
);
const SelectScreenTypeComponent = React.lazy(
() => import("./Dashboard/PermanentConfiguration/SelectScreenType")
() => import("./Dashboard/PermanentConfiguration/SelectScreenType"),
);

class AppRoutes extends React.Component {
Expand Down
4 changes: 2 additions & 2 deletions assets/js/components/Dashboard/AlertBanner.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@ const AlertBanner: ComponentType<AlertBannerProps> = ({
return translateRouteID(alert.affected_list[0]);
} else if (
alert.affected_list.every((routeId: string) =>
routeId.startsWith("green")
routeId.startsWith("green"),
)
) {
return "Green Line";
Expand Down Expand Up @@ -69,7 +69,7 @@ const AlertBanner: ComponentType<AlertBannerProps> = ({
<>
<span className="bold">
{`${aOrAn(
affectedListString
affectedListString,
)} ${affectedListString} ${formatEffect(alert.effect)}
alert was just closed.`}
</span>{" "}
Expand Down
2 changes: 1 addition & 1 deletion assets/js/components/Dashboard/AlertCard.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@ const AlertCard = (props: AlertCardProps): JSX.Element => {
numberOfScreens,
],
prevAlert,
showAnimationOnMount
showAnimationOnMount,
);
const isRecurring = alert.active_period.length > 1;

Expand Down
6 changes: 3 additions & 3 deletions assets/js/components/Dashboard/AlertDetails.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -54,11 +54,11 @@ const AlertDetails: ComponentType = () => {

const [placesListState, placesListDispatch] = useReducer(
placesListReducer,
initialPlacesListState
initialPlacesListState,
);

const validAlertId = contextState.allAPIAlertIds.find(
(alert) => alert === id
(alert) => alert === id,
);

return selectedAlert ? (
Expand Down Expand Up @@ -93,7 +93,7 @@ const AlertDetails: ComponentType = () => {
places={placesWithSelectedAlert(
selectedAlert,
places,
screensByAlertMap
screensByAlertMap,
)}
noModeFilter
isAlertPlacesList
Expand Down
16 changes: 8 additions & 8 deletions assets/js/components/Dashboard/AlertsPage.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ const AlertsPage: ComponentType = () => {
const { places, alerts, screensByAlertMap } = useScreenplayContext();

const alertsWithPlaces = alerts.filter(
(alert) => screensByAlertMap[alert.id]
(alert) => screensByAlertMap[alert.id],
);

return (
Expand Down Expand Up @@ -117,7 +117,7 @@ const AlertsList: ComponentType<AlertsListProps> = ({
numPlaces = placesWithSelectedAlert(
alert,
places,
screensByAlertMap
screensByAlertMap,
).length;
}

Expand Down Expand Up @@ -145,22 +145,22 @@ const AlertsList: ComponentType<AlertsListProps> = ({
if (screenTypeFilterValue !== SCREEN_TYPES[0]) {
filteredAlerts = filterAlertsByScreenType(
filteredAlerts,
screenTypeFilterValue
screenTypeFilterValue,
);
}

if (modeLineFilterValue !== MODES_AND_LINES[0]) {
filteredAlerts = filterAlertsByModeOrLine(
filteredAlerts,
modeLineFilterValue
modeLineFilterValue,
);
}
return filteredAlerts;
};

const filterAlertsByModeOrLine = (
alerts: Alert[],
{ label, ids }: { label: string; ids: string[] }
{ label, ids }: { label: string; ids: string[] },
) => {
const isRelevantIE: (ie: InformedEntity) => boolean = (() => {
switch (label) {
Expand Down Expand Up @@ -197,23 +197,23 @@ const AlertsList: ComponentType<AlertsListProps> = ({

const filterAlertsByScreenType = (
alerts: Alert[],
{ ids }: { label: string; ids: string[] }
{ ids }: { label: string; ids: string[] },
) => {
return alerts.filter((alert) => {
// Get this alert's list of affected screens.
const screensWithAlert = screensByAlertMap[alert.id];

return screensWithAlert
? screensWithAlert.find((screen_id) =>
ids.includes(screenMetaData[screen_id].type)
ids.includes(screenMetaData[screen_id].type),
)
: false;
});
};

const compareAlerts = (
{ active_period: active_period_1 }: Alert,
{ active_period: active_period_2 }: Alert
{ active_period: active_period_2 }: Alert,
) => {
// Get the soonest start time
const start1 = moment(active_period_1[0].start);
Expand Down
10 changes: 5 additions & 5 deletions assets/js/components/Dashboard/Dashboard.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -34,11 +34,11 @@ const Dashboard: ComponentType = () => {
allAPIAlertIds: allAPIalertIds,
screensByAlertMap: screensByAlertMap,
});
}
},
);

fetchPlaces().then((placesList) =>
dispatch({ type: "SET_PLACES", places: placesList })
dispatch({ type: "SET_PLACES", places: placesList }),
);
}, []);

Expand All @@ -57,7 +57,7 @@ const Dashboard: ComponentType = () => {
allAPIAlertIds: allAPIalertIds,
screensByAlertMap: screensByAlertMap,
});
}
},
);
}, 4000);

Expand Down Expand Up @@ -129,7 +129,7 @@ const Dashboard: ComponentType = () => {
})
// sort them in descending order to get the most recently created or updated alert
.sort((a1, a2) =>
new Date(a1.updated_at) < new Date(a2.updated_at) ? 1 : -1
new Date(a1.updated_at) < new Date(a2.updated_at) ? 1 : -1,
)
// get the first alert in the list or underfined if there are none
.find((alert) => alert)
Expand All @@ -143,7 +143,7 @@ const Dashboard: ComponentType = () => {
type: "SET_BANNER_ALERT",
bannerAlert: undefined,
}),
5000
5000,
);
};

Expand Down
8 changes: 4 additions & 4 deletions assets/js/components/Dashboard/FilterDropdown.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,7 @@ const CustomMenu = React.forwardRef<HTMLElement, CustomMenuProps>(
<ul>{children}</ul>
</div>
);
}
},
);

/**
Expand All @@ -62,7 +62,7 @@ const FilterDropdown = (props: FilterDropdownProps): JSX.Element => {
"filter-dropdown__dropdown-button--small": !isDefault(),
"filter-dropdown__dropdown-button--large": isDefault(),
disabled: props.disabled,
}
},
)}
title={props.disabled ? "Coming Soon!" : selectedValue.label}
data-testid="filter-dropdown-button"
Expand All @@ -79,7 +79,7 @@ const FilterDropdown = (props: FilterDropdownProps): JSX.Element => {
<ButtonGroup
className={classWithModifier(
"filter-dropdown__button-group",
props.className
props.className,
)}
>
{!isDefault() && (
Expand All @@ -98,7 +98,7 @@ const FilterDropdown = (props: FilterDropdownProps): JSX.Element => {
onSelect={onSelect}
className={classWithModifier(
"filter-dropdown__dropdown",
props.className
props.className,
)}
>
{props.disabled ? (
Expand Down
Loading

0 comments on commit ee0a66e

Please sign in to comment.