Some checks failed
Main Confidence / confidence (push) Failing after 45s
## Summary - introduce surface-aware compressed governance outcomes and reuse the shared truth/explanation seams for operator-first summaries - apply the compressed outcome hierarchy across baseline, evidence, review, review-pack, canonical review/evidence, and artifact-oriented operation-run surfaces - expand spec 214 fixtures and Pest coverage, and fix tenant-panel route assertions by generating explicit tenant-panel URLs in the affected Filament tests ## Validation - `cd apps/platform && ./vendor/bin/sail bin pint --dirty --format agent` - focused governance compression suite from `specs/214-governance-outcome-compression/quickstart.md` passed (`68` tests, `445` assertions) - `cd apps/platform && ./vendor/bin/sail artisan test --compact tests/Feature/Filament/InventoryItemResourceTest.php tests/Feature/Filament/BackupSetUiEnforcementTest.php tests/Feature/Filament/RestoreRunUiEnforcementTest.php` passed (`18` tests, `81` assertions) Co-authored-by: Ahmed Darrazi <ahmed.darrazi@live.de> Reviewed-on: #253
30 lines
2.3 KiB
Plaintext
30 lines
2.3 KiB
Plaintext
import { Observable } from '../Observable';
|
|
import { Unsubscribable, ObservableInput, ObservedValueOf } from '../types';
|
|
/**
|
|
* Creates an Observable that uses a resource which will be disposed at the same time as the Observable.
|
|
*
|
|
* <span class="informal">Use it when you catch yourself cleaning up after an Observable.</span>
|
|
*
|
|
* `using` is a factory operator, which accepts two functions. First function returns a disposable resource.
|
|
* It can be an arbitrary object that implements `unsubscribe` method. Second function will be injected with
|
|
* that object and should return an Observable. That Observable can use resource object during its execution.
|
|
* Both functions passed to `using` will be called every time someone subscribes - neither an Observable nor
|
|
* resource object will be shared in any way between subscriptions.
|
|
*
|
|
* When Observable returned by `using` is subscribed, Observable returned from the second function will be subscribed
|
|
* as well. All its notifications (nexted values, completion and error events) will be emitted unchanged by the output
|
|
* Observable. If however someone unsubscribes from the Observable or source Observable completes or errors by itself,
|
|
* the `unsubscribe` method on resource object will be called. This can be used to do any necessary clean up, which
|
|
* otherwise would have to be handled by hand. Note that complete or error notifications are not emitted when someone
|
|
* cancels subscription to an Observable via `unsubscribe`, so `using` can be used as a hook, allowing you to make
|
|
* sure that all resources which need to exist during an Observable execution will be disposed at appropriate time.
|
|
*
|
|
* @see {@link defer}
|
|
*
|
|
* @param resourceFactory A function which creates any resource object that implements `unsubscribe` method.
|
|
* @param observableFactory A function which creates an Observable, that can use injected resource object.
|
|
* @return An Observable that behaves the same as Observable returned by `observableFactory`, but
|
|
* which - when completed, errored or unsubscribed - will also call `unsubscribe` on created resource object.
|
|
*/
|
|
export declare function using<T extends ObservableInput<any>>(resourceFactory: () => Unsubscribable | void, observableFactory: (resource: Unsubscribable | void) => T | void): Observable<ObservedValueOf<T>>;
|
|
//# sourceMappingURL=using.d.ts.map |