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
79 lines
2.8 KiB
Plaintext
79 lines
2.8 KiB
Plaintext
import { innerFrom } from '../observable/innerFrom';
|
|
import { Subject } from '../Subject';
|
|
import { SafeSubscriber } from '../Subscriber';
|
|
import { operate } from '../util/lift';
|
|
export function share(options = {}) {
|
|
const { connector = () => new Subject(), resetOnError = true, resetOnComplete = true, resetOnRefCountZero = true } = options;
|
|
return (wrapperSource) => {
|
|
let connection;
|
|
let resetConnection;
|
|
let subject;
|
|
let refCount = 0;
|
|
let hasCompleted = false;
|
|
let hasErrored = false;
|
|
const cancelReset = () => {
|
|
resetConnection === null || resetConnection === void 0 ? void 0 : resetConnection.unsubscribe();
|
|
resetConnection = undefined;
|
|
};
|
|
const reset = () => {
|
|
cancelReset();
|
|
connection = subject = undefined;
|
|
hasCompleted = hasErrored = false;
|
|
};
|
|
const resetAndUnsubscribe = () => {
|
|
const conn = connection;
|
|
reset();
|
|
conn === null || conn === void 0 ? void 0 : conn.unsubscribe();
|
|
};
|
|
return operate((source, subscriber) => {
|
|
refCount++;
|
|
if (!hasErrored && !hasCompleted) {
|
|
cancelReset();
|
|
}
|
|
const dest = (subject = subject !== null && subject !== void 0 ? subject : connector());
|
|
subscriber.add(() => {
|
|
refCount--;
|
|
if (refCount === 0 && !hasErrored && !hasCompleted) {
|
|
resetConnection = handleReset(resetAndUnsubscribe, resetOnRefCountZero);
|
|
}
|
|
});
|
|
dest.subscribe(subscriber);
|
|
if (!connection &&
|
|
refCount > 0) {
|
|
connection = new SafeSubscriber({
|
|
next: (value) => dest.next(value),
|
|
error: (err) => {
|
|
hasErrored = true;
|
|
cancelReset();
|
|
resetConnection = handleReset(reset, resetOnError, err);
|
|
dest.error(err);
|
|
},
|
|
complete: () => {
|
|
hasCompleted = true;
|
|
cancelReset();
|
|
resetConnection = handleReset(reset, resetOnComplete);
|
|
dest.complete();
|
|
},
|
|
});
|
|
innerFrom(source).subscribe(connection);
|
|
}
|
|
})(wrapperSource);
|
|
};
|
|
}
|
|
function handleReset(reset, on, ...args) {
|
|
if (on === true) {
|
|
reset();
|
|
return;
|
|
}
|
|
if (on === false) {
|
|
return;
|
|
}
|
|
const onSubscriber = new SafeSubscriber({
|
|
next: () => {
|
|
onSubscriber.unsubscribe();
|
|
reset();
|
|
},
|
|
});
|
|
return innerFrom(on(...args)).subscribe(onSubscriber);
|
|
}
|
|
//# sourceMappingURL=share.js.map |