-
-
Notifications
You must be signed in to change notification settings - Fork 1.1k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
feat: Random Failures #7821
Open
Maverickwoe
wants to merge
292
commits into
flybywiresim:master
Choose a base branch
from
Maverickwoe:a32nx-RandomFailures
base: master
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Open
feat: Random Failures #7821
Changes from 250 commits
Commits
Show all changes
292 commits
Select commit
Hold shift + click to select a range
3f00202
new individual Failures for generators
Maverickwoe 7699efd
fix declaration of all failure hooks at each step
Maverickwoe 0a86139
fixed failureList generation
Maverickwoe b893f55
added init for all failures
Maverickwoe 5fe8c9b
attempt to display a new generator tab in failure
Maverickwoe 07edd9b
fixed first layer tab for failures
Maverickwoe 242579b
fix relative routing for comfort view
Maverickwoe 7f755a5
changed translation structure
Maverickwoe 98ce590
fix of ATAChapter with new relative path
Maverickwoe a5a88ba
Attempt to add generator selector
Maverickwoe 6fd1514
optimized failureGenerator array outside of hooks
Maverickwoe 660153b
attempt to show one button per generator - BUGGED
Maverickwoe b6eaf3a
added structure for all settings
Maverickwoe f547acb
Attempf to fix fail gen cards display
Maverickwoe 6cd041b
added content to TAke Off failure card
Maverickwoe 987d3fb
fix undefined setting
Maverickwoe 25fe94e
take off setting input fields
Maverickwoe 0a6a909
take off: replaced usestate by global var
Maverickwoe 0e3e142
fix wrong index on altitude setting
Maverickwoe 0e6e6cf
optimize setting split once per display
Maverickwoe 22fbd1d
replace raw string setting with table
Maverickwoe 474f33e
fix wrong min max in take off settings
Maverickwoe 46dcb92
replace string setting by table verywhere
Maverickwoe ea00bad
added button for rearm type
Maverickwoe 879be6c
added Max Number of failure display
Maverickwoe eee8201
Major visual improv of take off card
Maverickwoe 37eeb71
fix add generator with array instead of string
Maverickwoe 89f79de
centering of bin icon
Maverickwoe bfcc7a2
Factoring TakeOff settings and rearm
Maverickwoe 6bc71a0
added check for corrupted settings Take off
Maverickwoe 9dba7bb
protect against undefined settings
Maverickwoe 88e6932
excluding split result instead of string itself
Maverickwoe f537d6a
fix newSetting still in strings
Maverickwoe 2219e63
same fix for perHour
Maverickwoe 5537cbe
renaming button to cards
Maverickwoe f854e71
fix wrong rearm button ID in refactor
Maverickwoe b541383
using factored components for PerHour
Maverickwoe 0c58c13
split files for alt failure
Maverickwoe d0e8e9d
replaced settings hook by var for Alt Gen
Maverickwoe 5f80609
Added Cards for altitude climb / desc
Maverickwoe 7ef9615
Split speed failure gens, renamed to singular
Maverickwoe 1e21d71
using vars instead of hooks for arm on speed gen
Maverickwoe c456fa1
Added Cards for speed gen
Maverickwoe b698973
fix error of setting choice
Maverickwoe 8cffbc3
created generator failures removal function
Maverickwoe 4620159
fix remaining border on takeoff card
Maverickwoe a1cc74e
fix rearm buttons always displaying takeoff gene
Maverickwoe b4ef546
recommit
Maverickwoe 88db0d8
fix missing argument in alt desc
Maverickwoe 2a6633e
fix setting number in alt climb
Maverickwoe a512055
reordered generator order of appearance
Maverickwoe 63fea26
fix wrong max on timer
Maverickwoe 9041f76
migrated UI in separate file
Maverickwoe 410e30a
adjust size of gen selection
Maverickwoe 1095afb
changed arm button look
Maverickwoe 5554e7d
Reuse of setting buttons instead for rearm
Maverickwoe 1ec8263
Major refactor through interface FailureGenData
Maverickwoe 4e450b4
Fix incorrect arguments for cards
Maverickwoe 6400013
moved UI of failure Setting
Maverickwoe ac8eda2
Further refactoring of CARDUI
Maverickwoe 7d81c0c
fix selector of gen with new refactor
Maverickwoe 8b86c08
fix relative route to comfort failures
Maverickwoe da042b8
minor fixes and tuning
Maverickwoe e889742
regroup all sub cards generatoin in one go
Maverickwoe 0a0386d
Replaced setting inputs by modal input
Maverickwoe a0139c3
moved randomFailure Gen to directory
Maverickwoe 145d25f
revert changes in Comfort.
Maverickwoe dc796d6
Migrated modal window to Routes
Maverickwoe ffed70c
file splitting for failure Selection
Maverickwoe 9dc6493
split failure selection UI
Maverickwoe 61f1d5f
Merge branch 'master' into a32nx-RandomFailures
Maverickwoe 654b7db
add capacity to not show takeOff Rearm
Maverickwoe 2df05a6
Localization french and english
Maverickwoe ac5b826
Remove all logs and comments
Maverickwoe 2ddbeb9
removed unuseful ":" in a gen
Maverickwoe dd55675
use simvar on takeoff altitude
Maverickwoe 3140ea3
adding by default all failures with new gen
Maverickwoe 9fa1c7d
Visual improvement of gen settings
Maverickwoe f02b8ef
change speed and altitude setting size
Maverickwoe 8a983c3
fix error in daysPerYear for MTTF
Maverickwoe a8e85a9
reducing operations for MTTF formula
Maverickwoe 2718153
Merge branch 'master' into a32nx-RandomFailures
Maverickwoe 86dd41d
Merge branch 'master' into a32nx-RandomFailures
Maverickwoe 0e543e3
backbone of new UI
Maverickwoe e0ae938
Using now a context for modal popups
Maverickwoe b8adb58
changed default arming policy for each gen
Maverickwoe 69cb9eb
Failure shortlist with chapters
Maverickwoe f69c855
fix improper failure handling when deleting card
Maverickwoe e4a3ea5
Altitude Climb/Desc has random between Min & Max
Maverickwoe 9a374b0
fix max altitude used for rearm of descent
Maverickwoe 319d6d8
commonalised climb and descent generators
Maverickwoe bf36113
gen speed and timer have min max
Maverickwoe 16fe094
fix : take off rearm on most gens
Maverickwoe 92d616e
Merge branch 'master' into a32nx-RandomFailures
Maverickwoe 80fff06
conflicting css
Maverickwoe 32f7f46
Merge branch 'a32nx-RandomFailures' of https://github.com/Maverickwoe…
Maverickwoe 089ed1d
Merge branch 'master' into a32nx-RandomFailures
Maverickwoe a0bcf4c
fix min max of take off settings
Maverickwoe 3661b64
Merge branch 'a32nx-RandomFailures' of https://github.com/Maverickwoe…
Maverickwoe 329e8cf
Translation French
Maverickwoe 4830fce
revert removed translation "All"
Maverickwoe 69c4a90
Merge branch 'master' into a32nx-RandomFailures
Maverickwoe a7d520e
fix takeOff arming using old indexes
Maverickwoe cd68b42
Major rehaul of settings visual
Maverickwoe 9c73556
font size for text only settings
Maverickwoe 4f2bc50
Merge branch 'master' into a32nx-RandomFailures
Maverickwoe 32d6c55
Sub section in take-off
Maverickwoe 47069f9
Update fbw-a32nx/src/systems/instruments/src/EFB/Failures/FailureGene…
Maverickwoe 486a8e9
removed setting from FailureGenData
Maverickwoe f106f0f
replaced GetSimVarValue by useSimVar
Maverickwoe a7f322b
Merge branch 'master' into a32nx-RandomFailures
Maverickwoe f6abd77
added periods to altitude and gs
Maverickwoe c637efb
Merge branch 'master' into a32nx-RandomFailures
2hwk 5a2e4f7
Merge branch 'master' into a32nx-RandomFailures
Maverickwoe cf0f0df
fix: No Failure properly displayed
Maverickwoe 84bd966
fix: using wrong index for chance over time
Maverickwoe 247272e
Merge branch 'master' into a32nx-RandomFailures
Maverickwoe 53362f9
Merge branch 'master' into a32nx-RandomFailures
Maverickwoe c941af8
Merge remote-tracking branch 'origin/master' into a32nx-RandomFailures
Saschl 9c1de2a
update imports
Saschl be181d6
fix: duplicate imports
Maverickwoe 9e03e74
Merge branch 'master' into a32nx-RandomFailures
Maverickwoe 41e944a
Merge branch 'master' into a32nx-RandomFailures
Maverickwoe 5e219fe
add default dropdown selection
Maverickwoe 987f721
change generator description
Maverickwoe f4dd6cf
Change prob. during climb to include high speed
Maverickwoe 57d7ad7
simplified info description with URL
Maverickwoe c314983
Reorg of localization
Maverickwoe c9bfdee
Typo "its settings"
Maverickwoe f89552f
fix localization to info title
Maverickwoe a966455
Max simult failure moved to each gen's settings
Maverickwoe b7e1ac4
Merge branch 'master' into a32nx-RandomFailures
Maverickwoe 6d6cb4c
Less periodicities in the generators
Maverickwoe e97709b
Merge branch 'master' into a32nx-RandomFailures
Maverickwoe 4234215
Merge branch 'master' into a32nx-RandomFailures
Maverickwoe c4c6360
Merge branch 'master' into a32nx-RandomFailures
Maverickwoe 1194cf4
fix: speed and alti gen fixed on decrease+TO mode
Maverickwoe 9695590
fix: TakeOff Gen arms below minSpeed instead of 1
Maverickwoe 1ee147c
WIP : Migrate arming and trigger logic to non EFB
Maverickwoe 026a69a
migrated Altitude gen logic oustide EFB
Maverickwoe da0a6de
Merge branch 'master' into a32nx-RandomFailures
Maverickwoe 244c309
Speed failure gen migrated outside EFB
Maverickwoe 3224676
Migration of Timer failure gen outside of EFB
Maverickwoe 119d2a2
Failure over time Gen migrated outside of EFB
Maverickwoe f9134e4
final migration, Take Off failure gen outside EFB
Maverickwoe 6300147
fix: path for import
Maverickwoe ae1583a
attempt to solve wrong imports
Maverickwoe 9013871
fix: wrong path from maintenance reminder (EFB)
Maverickwoe 2f12894
-
Maverickwoe f3b510d
fix: import, Renamed tsx files to tsx
Maverickwoe 59d8302
fix: Using relative paths for imports
Maverickwoe b41bf63
fix: more incorrect links in maintenance reminders
Maverickwoe f3083f7
parsemetar change extension name
Maverickwoe 8da0046
revert tsx renaming on parseMetar
Maverickwoe cfb3672
attempt to fix jest tests
Saschl 90fa5cb
Merge remote-tracking branch 'fbw/master' into a32nx-RandomFailures
Saschl 141f3d7
Merge branch 'master' into a32nx-RandomFailures
Maverickwoe 6feccbc
Merge branch 'master' into a32nx-RandomFailures
Saschl caae8a1
removal of all console.log commented out
Maverickwoe 7845977
Update fbw-a32nx/src/systems/failures/src/AltitudeFailureGenerator.ts
Maverickwoe 594183b
fix changelog format
Maverickwoe 0b1ef28
remove extra lines in setupJestMock
Maverickwoe 8d7ebff
Update package.json
Maverickwoe f0e4b3d
change failures Flight State Enum format
Maverickwoe b653fdc
fix formatting for data typing
Maverickwoe 243e0a2
remove commented import
Maverickwoe b5617bc
change page route to "failure-list"
Maverickwoe 893e043
non-component functions starting with low case
Maverickwoe c96a8a3
correction of format type annotations in UI
Maverickwoe f39511f
MttfDisplay acronym to lower case
Maverickwoe 515d39b
remove unuseful type "Any" in failure query
Maverickwoe 68a4c4c
Lambda function formatting
Maverickwoe ce5c555
Update fbw-a32nx/src/systems/failures/src/AltitudeFailureGenerator.ts
Maverickwoe 45755d5
code formatting
Maverickwoe 23fe3c7
Merge branch 'master' into a32nx-RandomFailures
Maverickwoe b05896a
Merge branch 'a32nx-RandomFailures' of https://github.com/Maverickwoe…
Maverickwoe ab7b999
renamed didOnce with didInitialize
Maverickwoe 4b1c996
simplification of code
Maverickwoe 9fd42b2
fix: NaN inputs replaced by min input
Maverickwoe 43c6b35
TimedFailure in TakeOff mode starts when rolling
Maverickwoe cf44e94
timer generator follows same readiness logic
Maverickwoe 9f7b246
Added setting integrity check in generator updates
Maverickwoe b57c7d4
Applied new arming logic to PerHour gen
Maverickwoe a1c8d4f
add missing change flag for integrity check
Maverickwoe f2fb8e1
Add new arming logic to takeoff gen
Maverickwoe a214381
fix: chance per take off was not properly applied
Maverickwoe 9d5e044
Merge branch 'master' into a32nx-RandomFailures
Maverickwoe cc6c416
Merge branch 'master' into a32nx-RandomFailures
Maverickwoe d84feb5
Fix: setting shift when generator add or del
Maverickwoe 2c7f9a6
Merge branch 'a32nx-RandomFailures' of https://github.com/Maverickwoe…
Maverickwoe 636a651
Merge branch 'master' into a32nx-RandomFailures
Maverickwoe 7c3a44c
Refactor failure triggering code for all gen
Maverickwoe 8a2a255
Merge branch 'a32nx-RandomFailures' of https://github.com/Maverickwoe…
Maverickwoe c6e5cae
WIP Bus Communication Failure-->UI
Maverickwoe 38d51fa
refactor: use a single event bus instance for random failure generato…
Benjozork 3010335
fix bus communication from system to UI
Maverickwoe f96ea9a
System uses one event interface for all gen
Maverickwoe f4ca8d8
fix imports to relative paths
Maverickwoe 3bed9cf
replaced simplane with simvar for alt and gs
Maverickwoe eb97386
Setting Event reworked
Maverickwoe ac37a43
improvement of UI and system sync
Maverickwoe 41a6e50
refactor: part 1: remove unnecessary context being passed around
Benjozork 588d0f1
refactor: part 2: move functions into components
Benjozork 0c84bf0
refactor: part 2: move functions into components
Benjozork f7a5e43
Merge branch 'master' into a32nx-RandomFailures
Maverickwoe 1b470cc
resynch of branch
Maverickwoe 6bfc416
answer to comments
Maverickwoe 0a8a91d
New bus event for Failure pool
Maverickwoe ffa7f21
unecessary import
Maverickwoe b6b75b7
Component at EFB load for 1st setting broadcast
Maverickwoe a29a954
Filtering of ATA chapters in short list of card
Maverickwoe a75014f
bitflags imports and double definition
Maverickwoe 15da8ac
removed unecessary broadcasts at page load
Maverickwoe 89d3edc
Merge branch 'master' into a32nx-RandomFailures
tracernz 08b3aad
fix: added settings to dependency array
Saschl a7523ca
removed duplicate condition
Saschl e2647e9
UI event subscription refactored
Maverickwoe d40d623
Merge branch 'master' into a32nx-RandomFailures
Maverickwoe 2bf3fe9
attempt to fix test suite
Maverickwoe c4a754f
enums and intermediate variable for description
Maverickwoe cc62905
further enum creations on system side
Maverickwoe 6a51dd5
fix: revert env
Saschl 6ef6deb
cleaned up dead code
Maverickwoe 0e2a962
Fixed Altitude min max values behaviour
Maverickwoe 1cfc9f7
Merge branch 'master' into a32nx-RandomFailures
Maverickwoe 9e7239b
Renaming EFB files
Maverickwoe 9746dfe
Merge branch 'a32nx-RandomFailures' of https://github.com/Maverickwoe…
Maverickwoe 7e43029
failure selection has 3-state checkboxes
Maverickwoe b38da31
Improvement of Failure selection UI layout
Maverickwoe cf9565e
modal window state "currently displayed"
Maverickwoe 8b8315a
test to avoid unecessary hook set
Maverickwoe b3d7a6f
attempt to improve NaN values
Saschl ec97b00
Subscription to events happens once now
Maverickwoe ba27dd5
Merge branch 'a32nx-RandomFailures' of https://github.com/Maverickwoe…
Maverickwoe 91999d7
modal window state "currently displayed"
Maverickwoe e6874c3
No pop up display if content is null or NaN
Maverickwoe f7e7f8a
closing modal flushs modal context
Maverickwoe 938dad7
file separation of FailureGenCardTemplate
Maverickwoe ad5ea94
FailureShortList moved to different file
Maverickwoe 420be86
setting modal now updates when mode OFF
Maverickwoe 14602bf
Merge branch 'master' into a32nx-RandomFailures
Maverickwoe 951c631
subscription to events on 'settings' dependency
Maverickwoe 2e34d93
layout of Next button in triggering conditions
Maverickwoe 689e8ad
fix default size of scrollable zone
Maverickwoe 44205da
Merge branch 'master' into a32nx-RandomFailures
Maverickwoe 4117ecd
Merge branch 'master' into a32nx-RandomFailures
Maverickwoe 6cfd373
Merge remote-tracking branch 'origin/master' into a32nx-RandomFailures
Saschl 10306e0
fixes after big merge
Saschl 4ed7c19
fix: commbus things
Saschl a0e7878
fix: lint
Saschl File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,5 +1,5 @@ | ||
VITE_BUILD=false | ||
NODE_ENV=production | ||
CLIENT_SECRET="" | ||
CLIENT_ID="" | ||
CLIENT_SECRET="Gj87HjKMfHd983WM978Kdhqos3kjsdO4bc3" | ||
CLIENT_ID="fbw-a32nx" | ||
SENTRY_DSN="" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
69 changes: 69 additions & 0 deletions
69
fbw-a32nx/src/systems/failures/src/AltitudeFailureGenerator.ts
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,69 @@ | ||
// Copyright (c) 2021-2023 FlyByWire Simulations | ||
// | ||
// SPDX-License-Identifier: GPL-3.0 | ||
|
||
import { GenericGenerator } from './GenericGenerator'; | ||
|
||
export class FailureGeneratorAltitude extends GenericGenerator { | ||
numberOfSettingsPerGenerator = 6; | ||
|
||
uniqueGenPrefix: string = 'A'; | ||
|
||
private rolledDice: number[] = []; | ||
|
||
private previousAltitudeCondition: number[] = []; | ||
|
||
private altitudeConditionIndex = 3; | ||
|
||
private altitudeMinIndex = 4; | ||
|
||
private altitudeMaxIndex = 5; | ||
|
||
private resetMargin = 100; | ||
|
||
private altitude: number; | ||
|
||
loopStartAction(): void { | ||
this.altitude = SimVar.GetSimVarValue('INDICATED ALTITUDE', 'Feet') || '0'; | ||
} | ||
|
||
additionalInitActions(genNumber: number): void { | ||
this.previousAltitudeCondition[genNumber] = this.settings[genNumber * this.numberOfSettingsPerGenerator | ||
+ this.altitudeConditionIndex]; | ||
} | ||
|
||
generatorSpecificActions(genNumber: number): void { | ||
const altitudeCondition = this.settings[genNumber * this.numberOfSettingsPerGenerator + this.altitudeConditionIndex]; | ||
|
||
if (this.previousAltitudeCondition[genNumber] !== altitudeCondition) { | ||
this.disarm(genNumber); | ||
} | ||
} | ||
|
||
conditionToTriggerFailure(genNumber: number): boolean { | ||
const altitudeMax = this.settings[genNumber * this.numberOfSettingsPerGenerator + this.altitudeMaxIndex] * 100; | ||
const altitudeMin = this.settings[genNumber * this.numberOfSettingsPerGenerator + this.altitudeMinIndex] * 100; | ||
const altitudeCondition = this.settings[genNumber * this.numberOfSettingsPerGenerator + this.altitudeConditionIndex]; | ||
const failureAltitude = (altitudeMin + this.rolledDice[genNumber] * (altitudeMax - altitudeMin)); | ||
|
||
return ((this.altitude > failureAltitude && altitudeCondition === 0) | ||
|| (this.altitude < failureAltitude && altitudeCondition === 1)); | ||
} | ||
|
||
conditionToArm(genNumber: number): boolean { | ||
const altitudeMax = this.settings[genNumber * this.numberOfSettingsPerGenerator + this.altitudeMaxIndex] * 100; | ||
const altitudeMin = this.settings[genNumber * this.numberOfSettingsPerGenerator + this.altitudeMinIndex] * 100; | ||
const altitudeCondition = this.settings[genNumber * this.numberOfSettingsPerGenerator + this.altitudeConditionIndex]; | ||
return ((this.altitude < altitudeMin - this.resetMargin && altitudeCondition === 0) | ||
|| (this.altitude > altitudeMax + this.resetMargin && altitudeCondition === 1)); | ||
} | ||
|
||
additionalArmingActions(genNumber: number): void { | ||
this.rolledDice[genNumber] = Math.random(); | ||
} | ||
|
||
additionalGenEndActions(genNumber: number): void { | ||
this.previousAltitudeCondition[genNumber] = this.settings[genNumber * this.numberOfSettingsPerGenerator | ||
+ this.altitudeConditionIndex]; | ||
} | ||
} |
Oops, something went wrong.
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Please rebase/merge and move to 0.13.0.