@rcsb/rcsb-saguaro-app
Version:
RCSB 1D Saguaro Web App
70 lines • 4.37 kB
JavaScript
import { __awaiter } from "tslib";
import { FieldName, OperationType, SequenceReference, AnnotationReference, FeaturesType } from "@rcsb/rcsb-api-tools/lib/RcsbGraphQL/Types/Borrego/GqlTypes";
import { RcsbFvAbstractModule } from "./RcsbFvAbstractModule";
import { rcsbClient } from "../../RcsbGraphQL/RcsbClient";
import { MsaAlignmentTrackFactory } from "../RcsbFvFactories/RcsbFvTrackFactory/TrackFactoryImpl/MsaAlignmentTrackFactory";
import { Assertions } from "../../RcsbUtils/Helpers/Assertions";
var assertDefined = Assertions.assertDefined;
export class RcsbFvUniprot extends RcsbFvAbstractModule {
protectedBuild() {
return __awaiter(this, void 0, void 0, function* () {
var _a, _b, _c, _d;
const buildConfig = this.buildConfig;
const upAcc = buildConfig.upAcc;
assertDefined(upAcc);
const source = [AnnotationReference.Uniprot];
const alignmentRequestContext = {
queryId: upAcc,
from: SequenceReference.Uniprot,
to: SequenceReference.PdbEntity,
dynamicDisplay: false,
fitTitleWidth: true,
excludeFirstRowLink: true,
externalTrackBuilder: (_a = buildConfig.additionalConfig) === null || _a === void 0 ? void 0 : _a.externalTrackBuilder
};
const alignmentResponse = yield this.alignmentCollector.collect(alignmentRequestContext, (_b = buildConfig.additionalConfig) === null || _b === void 0 ? void 0 : _b.alignmentFilter);
const trackFactory = new MsaAlignmentTrackFactory(this.getPolymerEntityInstanceTranslator());
const alignmentFeatures = yield collectFeatures(upAcc);
yield trackFactory.prepareFeatures(alignmentFeatures.map(af => { var _a; return (Object.assign(Object.assign({}, af), { feature: (_a = af.features) === null || _a === void 0 ? void 0 : _a.filter(f => (f === null || f === void 0 ? void 0 : f.type) == FeaturesType.UnobservedResidueXyz) })); }), alignmentFeatures.map(af => { var _a; return (Object.assign(Object.assign({}, af), { feature: (_a = af.features) === null || _a === void 0 ? void 0 : _a.filter(f => (f === null || f === void 0 ? void 0 : f.type) == FeaturesType.MaQaMetricLocalTypePlddt) })); }));
yield this.buildAlignmentTracks(alignmentRequestContext, alignmentResponse, {
alignmentTrackFactory: trackFactory
});
const annotationsRequestContext = {
queryId: upAcc,
reference: SequenceReference.Uniprot,
sources: source,
annotationProcessing: (_c = buildConfig.additionalConfig) === null || _c === void 0 ? void 0 : _c.annotationProcessing,
externalTrackBuilder: (_d = buildConfig.additionalConfig) === null || _d === void 0 ? void 0 : _d.externalTrackBuilder
};
const annotationsFeatures = yield this.annotationCollector.collect(annotationsRequestContext);
yield this.buildAnnotationsTrack(annotationsRequestContext, annotationsFeatures);
this.boardConfigData.length = yield this.alignmentCollector.getAlignmentLength();
this.boardConfigData.includeAxis = true;
return void 0;
});
}
concatAlignmentAndAnnotationTracks() {
var _a;
const buildConfig = this.buildConfig;
this.rowConfigData = !((_a = buildConfig.additionalConfig) === null || _a === void 0 ? void 0 : _a.hideAlignments) ?
[this.referenceTrack].concat(this.annotationTracks).concat(this.alignmentTracks)
:
[this.referenceTrack].concat(this.annotationTracks);
}
}
function collectFeatures(upAcc) {
return __awaiter(this, void 0, void 0, function* () {
return yield rcsbClient.requestRcsbPdbAnnotations({
queryId: upAcc,
reference: SequenceReference.Uniprot,
sources: [AnnotationReference.PdbInstance],
filters: [{
source: AnnotationReference.PdbInstance,
operation: OperationType.Equals,
field: FieldName.Type,
values: [FeaturesType.UnobservedResidueXyz, FeaturesType.MaQaMetricLocalTypePlddt]
}]
});
});
}
//# sourceMappingURL=RcsbFvUniprot.js.map