UNPKG

@rcsb/rcsb-saguaro-app

Version:
70 lines 4.37 kB
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