@teselagen/sequence-utils 0.3.7 → 0.3.9

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (108) hide show
  1. package/README.md +89 -0
  2. package/bioData.d.ts +1 -339
  3. package/filterSequenceString.d.ts +26 -1
  4. package/index.d.ts +7 -8
  5. package/index.js +329 -413
  6. package/index.mjs +329 -413
  7. package/index.umd.js +329 -413
  8. package/package.json +1 -2
  9. package/src/addGapsToSeqReads.js +2 -2
  10. package/src/adjustAnnotationsToInsert.js +3 -3
  11. package/src/adjustBpsToReplaceOrInsert.js +3 -3
  12. package/src/adjustBpsToReplaceOrInsert.test.js +0 -1
  13. package/src/aminoAcidToDnaRna.test.js +1 -1
  14. package/src/annotateSingleSeq.js +1 -1
  15. package/src/annotateSingleSeq.test.js +1 -4
  16. package/src/autoAnnotate.js +5 -2
  17. package/src/autoAnnotate.test.js +6 -30
  18. package/src/bioData.js +1 -366
  19. package/src/calculateNebTa.js +1 -1
  20. package/src/calculateNebTm.js +1 -1
  21. package/src/calculatePercentGC.js +2 -2
  22. package/src/calculateTm.js +19 -102
  23. package/src/computeDigestFragments.js +7 -4
  24. package/src/computeDigestFragments.test.js +1 -1
  25. package/src/condensePairwiseAlignmentDifferences.js +1 -1
  26. package/src/convertAACaretPositionOrRangeToDna.js +1 -1
  27. package/src/convertDnaCaretPositionOrRangeToAA.js +1 -1
  28. package/src/cutSequenceByRestrictionEnzyme.js +3 -3
  29. package/src/cutSequenceByRestrictionEnzyme.test.js +0 -1
  30. package/src/degenerateDnaToAminoAcidMap.js +1 -1
  31. package/src/degenerateRnaToAminoAcidMap.js +1 -1
  32. package/src/deleteSequenceDataAtRange.js +1 -1
  33. package/src/deleteSequenceDataAtRange.test.js +23 -9
  34. package/src/diffUtils.js +4 -4
  35. package/src/diffUtils.test.js +2 -2
  36. package/src/doesEnzymeChopOutsideOfRecognitionSite.js +1 -1
  37. package/src/doesEnzymeChopOutsideOfRecognitionSite.test.js +0 -2
  38. package/src/featureTypesAndColors.js +5 -5
  39. package/src/featureTypesAndColors.test.js +1 -1
  40. package/src/filterSequenceString.js +111 -16
  41. package/src/filterSequenceString.test.js +62 -3
  42. package/src/findNearestRangeOfSequenceOverlapToPosition.js +1 -1
  43. package/src/findOrfsInPlasmid.js +1 -1
  44. package/src/findSequenceMatches.js +9 -10
  45. package/src/generateAnnotations.js +1 -1
  46. package/src/generateSequenceData.js +1 -1
  47. package/src/generateSequenceData.test.js +1 -1
  48. package/src/getAllInsertionsInSeqReads.js +1 -1
  49. package/src/getAminoAcidDataForEachBaseOfDna.js +2 -2
  50. package/src/getAminoAcidDataForEachBaseOfDna.test.js +0 -2
  51. package/src/getAminoAcidFromSequenceTriplet.js +1 -1
  52. package/src/getAminoAcidStringFromSequenceString.js +1 -1
  53. package/src/getCodonRangeForAASliver.js +1 -1
  54. package/src/getComplementAminoAcidStringFromSequenceString.js +2 -5
  55. package/src/getComplementSequenceAndAnnotations.js +1 -2
  56. package/src/getComplementSequenceString.js +5 -3
  57. package/src/getComplementSequenceString.test.js +6 -6
  58. package/src/getCutsiteType.js +1 -1
  59. package/src/getCutsitesFromSequence.js +1 -1
  60. package/src/getDegenerateDnaStringFromAAString.js +1 -1
  61. package/src/getDegenerateRnaStringFromAAString.js +1 -1
  62. package/src/getDigestFragmentsForCutsites.js +5 -2
  63. package/src/getDigestFragmentsForRestrictionEnzymes.js +2 -2
  64. package/src/getInsertBetweenVals.js +2 -2
  65. package/src/getLeftAndRightOfSequenceInRangeGivenPosition.js +2 -2
  66. package/src/getLeftAndRightOfSequenceInRangeGivenPosition.test.js +0 -2
  67. package/src/getMassOfAaString.js +4 -1
  68. package/src/getMassofAaString.test.js +9 -8
  69. package/src/getOrfsFromSequence.js +1 -2
  70. package/src/getOrfsFromSequence.test.js +1 -3
  71. package/src/getOverlapBetweenTwoSequences.js +3 -3
  72. package/src/getOverlapBetweenTwoSequences.test.js +1 -1
  73. package/src/getPossiblePartsFromSequenceAndEnzymes.js +2 -2
  74. package/src/getReverseAminoAcidStringFromSequenceString.js +1 -1
  75. package/src/getReverseComplementAminoAcidStringFromSequenceString.js +9 -6
  76. package/src/getReverseComplementAnnotation.js +1 -1
  77. package/src/getReverseComplementSequenceAndAnnotations.js +2 -3
  78. package/src/getReverseComplementSequenceString.js +1 -2
  79. package/src/getReverseSequenceString.js +1 -1
  80. package/src/getSequenceDataBetweenRange.js +7 -4
  81. package/src/getSequenceDataBetweenRange.test.js +0 -1
  82. package/src/getVirtualDigest.js +6 -3
  83. package/src/guessIfSequenceIsDnaAndNotProtein.js +2 -2
  84. package/src/index.js +79 -80
  85. package/src/index.test.js +5 -4
  86. package/src/insertGapsIntoRefSeq.js +1 -1
  87. package/src/insertSequenceDataAtPosition.test.js +4 -2
  88. package/src/insertSequenceDataAtPositionOrRange.js +5 -5
  89. package/src/insertSequenceDataAtPositionOrRange.test.js +3 -17
  90. package/src/isEnzymeType2S.js +1 -1
  91. package/src/mapAnnotationsToRows.js +3 -3
  92. package/src/mapAnnotationsToRows.test.js +1 -3
  93. package/src/prepareCircularViewData.js +5 -5
  94. package/src/prepareCircularViewData.test.js +1 -1
  95. package/src/prepareRowData.js +1 -2
  96. package/src/prepareRowData.test.js +1 -3
  97. package/src/prepareRowData_output1.json +381 -381
  98. package/src/proteinAlphabet.js +31 -26
  99. package/src/rotateBpsToPosition.js +7 -11
  100. package/src/rotateBpsToPosition.test.js +6 -6
  101. package/src/rotateSequenceDataToPosition.js +4 -4
  102. package/src/shiftAnnotationsByLen.js +2 -2
  103. package/src/tidyUpAnnotation.js +8 -7
  104. package/src/tidyUpSequenceData.js +15 -18
  105. package/filterAminoAcidSequenceString.d.ts +0 -1
  106. package/filterAminoAcidSequenceString.test.d.ts +0 -1
  107. package/src/filterAminoAcidSequenceString.js +0 -13
  108. package/src/filterAminoAcidSequenceString.test.js +0 -22
@@ -2,7 +2,7 @@ import {
2
2
  isPositionWithinRange,
3
3
  getSequenceWithinRange,
4
4
  normalizePositionByRangeLength,
5
- isPositionCloserToRangeStartThanRangeEnd,
5
+ isPositionCloserToRangeStartThanRangeEnd
6
6
  } from "@teselagen/range-utils";
7
7
 
8
8
  export default function getLeftAndRightOfSequenceInRangeGivenPosition(
@@ -36,4 +36,4 @@ export default function getLeftAndRightOfSequenceInRangeGivenPosition(
36
36
  }
37
37
  }
38
38
  return result;
39
- };
39
+ }
@@ -1,5 +1,3 @@
1
-
2
-
3
1
  import chai from "chai";
4
2
  import cutSequenceByRestrictionEnzyme from "./cutSequenceByRestrictionEnzyme.js";
5
3
  import enzymeList from "./aliasedEnzymesByName";
@@ -20,5 +20,8 @@ export default function getMassOfAaString(
20
20
  if (divideByThree) {
21
21
  sumMass /= 3;
22
22
  }
23
+ if (aaString.length > 0) {
24
+ sumMass = sumMass + 18.0153;
25
+ }
23
26
  return Math.round(sumMass * 10 ** numsAfterDecimal) / 10 ** numsAfterDecimal;
24
- };
27
+ }
@@ -5,14 +5,15 @@ describe("getMassOfAaString", () => {
5
5
  it("an empty string has a mass of 0", () => {
6
6
  assert.equal(getMassOfAaString(""), 0);
7
7
  });
8
- it("A string with one amino acids returns the correct results", () => {
9
- assert.equal(getMassOfAaString("T"), 119.1);
10
- assert.equal(getMassOfAaString("A"), 89.1);
11
- assert.equal(getMassOfAaString("F"), 165.2);
8
+ it("string with one amino acid returns the correct results", () => {
9
+ assert.equal(getMassOfAaString("T"), 119.12);
10
+ assert.equal(getMassOfAaString("A"), 89.09);
11
+ assert.equal(getMassOfAaString("F"), 165.19);
12
12
  });
13
- it("A string a long string of amino acids returns the correct results", () => {
14
- assert.equal(getMassOfAaString("TAGATAFPFPFPA"), 1510.6);
15
- assert.equal(getMassOfAaString("TFPMAV"), 754.8);
16
- assert.equal(getMassOfAaString("TFPMAVTAGATAFPFPFPA"), 2265.4);
13
+ it("a long string of amino acids returns the correct results", () => {
14
+ assert.equal(getMassOfAaString("TAGATAFPFPFPA"), 1294.45);
15
+ assert.equal(getMassOfAaString("TFPMAV"), 664.81);
16
+ assert.equal(getMassOfAaString("TFPMAVTAGATAFPFPFPA"), 1941.25);
17
+ assert.equal(getMassOfAaString("ARNDCEQGHILKMFPSTWYV"), 2395.71);
17
18
  });
18
19
  });
@@ -1,7 +1,6 @@
1
1
  import shortid from "shortid";
2
2
  import getReverseComplementSequenceString from "./getReverseComplementSequenceString";
3
3
 
4
-
5
4
  /**
6
5
  * @private
7
6
  * Finds ORFs in a given DNA forward in a given frame.
@@ -121,4 +120,4 @@ export default function getOrfsFromSequence(options) {
121
120
  return false;
122
121
  });
123
122
  return nonDuplicatedOrfRanges;
124
- };
123
+ }
@@ -1,6 +1,4 @@
1
-
2
-
3
- import {expect} from "chai";
1
+ import { expect } from "chai";
4
2
 
5
3
  import getOrfsFromSequence from "./getOrfsFromSequence.js";
6
4
  // getOrfsFromSequence(frame, sequence, minimumOrfSize, forward, circular)
@@ -1,4 +1,4 @@
1
- import {modulatePositionByRange} from "@teselagen/range-utils";
1
+ import { modulatePositionByRange } from "@teselagen/range-utils";
2
2
 
3
3
  /**
4
4
  * This function gets the overlapping of one sequence to another based on sequence equality.
@@ -10,7 +10,7 @@ import {modulatePositionByRange} from "@teselagen/range-utils";
10
10
  */
11
11
  export default function getOverlapBetweenTwoSequences(
12
12
  sequenceToFind,
13
- sequenceToSearchIn,
13
+ sequenceToSearchIn
14
14
  ) {
15
15
  sequenceToSearchIn = sequenceToSearchIn.toLowerCase();
16
16
  sequenceToFind = sequenceToFind.toLowerCase();
@@ -27,4 +27,4 @@ export default function getOverlapBetweenTwoSequences(
27
27
  } else {
28
28
  return null;
29
29
  }
30
- };
30
+ }
@@ -1,4 +1,4 @@
1
- import {expect} from "chai";
1
+ import { expect } from "chai";
2
2
  import getOverlapBetweenTwoSequences from "./getOverlapBetweenTwoSequences.js";
3
3
  describe("getOverlapBetweenTwoSequences", () => {
4
4
  it("should get the range overlap given a seq and a seq to search in", () => {
@@ -1,5 +1,5 @@
1
1
  import getComplementSequenceString from "./getComplementSequenceString";
2
- import {normalizePositionByRangeLength} from "@teselagen/range-utils";
2
+ import { normalizePositionByRangeLength } from "@teselagen/range-utils";
3
3
  import cutSequenceByRestrictionEnzyme from "./cutSequenceByRestrictionEnzyme";
4
4
 
5
5
  export default function getPossiblePartsFromSequenceAndEnzyme(
@@ -67,7 +67,7 @@ export default function getPossiblePartsFromSequenceAndEnzyme(
67
67
  });
68
68
  return parts;
69
69
  }
70
- };
70
+ }
71
71
 
72
72
  function getPartBetweenEnzymesWithInclusiveOverhangs(cut1, cut2, seqLen) {
73
73
  const firstCutOffset = getEnzymeRelativeOffset(cut1.restrictionEnzyme);
@@ -17,4 +17,4 @@ export default function getReverseAminoAcidStringFromSequenceString(
17
17
  });
18
18
  aaString = aaArray.join("");
19
19
  return aaString;
20
- };
20
+ }
@@ -1,7 +1,10 @@
1
+ import getAminoAcidStringFromSequenceString from "./getAminoAcidStringFromSequenceString";
2
+ import getReverseComplementSequenceString from "./getReverseComplementSequenceString";
1
3
 
2
- import getAminoAcidStringFromSequenceString from './getAminoAcidStringFromSequenceString';
3
- import getReverseComplementSequenceString from './getReverseComplementSequenceString';
4
-
5
- export default function getReverseComplementAminoAcidStringFromSequenceString(sequenceString) {
6
- return getAminoAcidStringFromSequenceString(getReverseComplementSequenceString(sequenceString))
7
- };
4
+ export default function getReverseComplementAminoAcidStringFromSequenceString(
5
+ sequenceString
6
+ ) {
7
+ return getAminoAcidStringFromSequenceString(
8
+ getReverseComplementSequenceString(sequenceString)
9
+ );
10
+ }
@@ -20,4 +20,4 @@ export default function getReverseComplementAnnotation(
20
20
  forward: !annotation.forward,
21
21
  strand: annotation.strand === 1 ? -1 : 1
22
22
  });
23
- };
23
+ }
@@ -1,10 +1,9 @@
1
1
  import getReverseComplementSequenceString from "./getReverseComplementSequenceString";
2
2
  import getReverseComplementAnnotation from "./getReverseComplementAnnotation";
3
3
  import { annotationTypes } from "./annotationTypes";
4
- import {map} from "lodash";
4
+ import { map } from "lodash";
5
5
  import tidyUpSequenceData from "./tidyUpSequenceData";
6
6
 
7
-
8
7
  import getSequenceDataBetweenRange from "./getSequenceDataBetweenRange";
9
8
 
10
9
  // ac.throw([ac.string,ac.bool],arguments);
@@ -35,4 +34,4 @@ export default function getReverseComplementSequenceAndAnnoations(
35
34
  }, {})
36
35
  );
37
36
  return tidyUpSequenceData(newSeqObj, options);
38
- };
37
+ }
@@ -1,6 +1,5 @@
1
1
  import DNAComplementMap from "./DNAComplementMap";
2
2
 
3
-
4
3
  // ac.throw([ac.string,ac.bool],arguments);
5
4
  export default function getReverseComplementSequenceString(sequence) {
6
5
  // ac.throw([ac.string],arguments);
@@ -14,4 +13,4 @@ export default function getReverseComplementSequenceString(sequence) {
14
13
  reverseComplementSequenceString += revChar;
15
14
  }
16
15
  return reverseComplementSequenceString;
17
- };
16
+ }
@@ -9,4 +9,4 @@ export default function getReverseSequenceString(sequence) {
9
9
  reverseSequenceString += revChar;
10
10
  }
11
11
  return reverseSequenceString;
12
- };
12
+ }
@@ -1,8 +1,11 @@
1
- import {flatMap, extend, forEach, startCase} from "lodash";
2
- import {getRangeLength} from "@teselagen/range-utils";
1
+ import { flatMap, extend, forEach, startCase } from "lodash";
2
+ import { getRangeLength } from "@teselagen/range-utils";
3
3
  import convertDnaCaretPositionOrRangeToAa from "./convertDnaCaretPositionOrRangeToAA";
4
4
  import insertSequenceDataAtPosition from "./insertSequenceDataAtPosition";
5
- import {getSequenceWithinRange, getZeroedRangeOverlaps} from "@teselagen/range-utils";
5
+ import {
6
+ getSequenceWithinRange,
7
+ getZeroedRangeOverlaps
8
+ } from "@teselagen/range-utils";
6
9
  import tidyUpSequenceData from "./tidyUpSequenceData";
7
10
  import { annotationTypes } from "./annotationTypes";
8
11
 
@@ -79,7 +82,7 @@ export default function getSequenceDataBetweenRange(
79
82
  }
80
83
 
81
84
  return tidyUpSequenceData(seqDataToReturn, options);
82
- };
85
+ }
83
86
 
84
87
  function getAnnotationsBetweenRange(
85
88
  annotationsToBeAdjusted,
@@ -1,6 +1,5 @@
1
1
  //tnr: half finished test.
2
2
 
3
-
4
3
  import chai from "chai";
5
4
  import chaiSubset from "chai-subset";
6
5
 
@@ -1,8 +1,11 @@
1
1
  //UNDER CONSTRUCTION
2
2
 
3
- import {get} from "lodash";
3
+ import { get } from "lodash";
4
4
 
5
- import {normalizePositionByRangeLength, getRangeLength} from "@teselagen/range-utils";
5
+ import {
6
+ normalizePositionByRangeLength,
7
+ getRangeLength
8
+ } from "@teselagen/range-utils";
6
9
 
7
10
  export default function getVirtualDigest({
8
11
  cutsites,
@@ -99,7 +102,7 @@ export default function getVirtualDigest({
99
102
  fragments,
100
103
  overlappingEnzymes
101
104
  };
102
- };
105
+ }
103
106
 
104
107
  function addSizeIdName(frag, sequenceLength) {
105
108
  const size = getRangeLength(
@@ -1,4 +1,4 @@
1
- import {ambiguous_dna_letters} from "./bioData";
1
+ import { ambiguous_dna_letters } from "./bioData";
2
2
 
3
3
  export default function guessIfSequenceIsDnaAndNotProtein(seq, options = {}) {
4
4
  const { threshold = 0.9, loose } = options;
@@ -30,4 +30,4 @@ export default function guessIfSequenceIsDnaAndNotProtein(seq, options = {}) {
30
30
  return true; //it is DNA
31
31
  }
32
32
  return false; //it is protein
33
- };
33
+ }
package/src/index.js CHANGED
@@ -1,19 +1,19 @@
1
1
  import {
2
2
  autoAnnotate,
3
3
  convertApELikeRegexToRegex,
4
- convertProteinSeqToDNAIupac,
5
- } from './autoAnnotate';
4
+ convertProteinSeqToDNAIupac
5
+ } from "./autoAnnotate";
6
6
 
7
7
  import {
8
8
  genbankFeatureTypes,
9
9
  getFeatureToColorMap,
10
10
  getFeatureTypes,
11
- getMergedFeatureMap,
12
- } from './featureTypesAndColors';
11
+ getMergedFeatureMap
12
+ } from "./featureTypesAndColors";
13
13
 
14
- export * from './computeDigestFragments';
15
- export * from './diffUtils';
16
- export * from './annotationTypes';
14
+ export * from "./computeDigestFragments";
15
+ export * from "./diffUtils";
16
+ export * from "./annotationTypes";
17
17
 
18
18
  /* ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ */
19
19
  //tnr: these are deprecated exports and should no longer be used!
@@ -25,82 +25,81 @@ export {
25
25
  genbankFeatureTypes,
26
26
  getMergedFeatureMap,
27
27
  FeatureTypes,
28
- featureColors,
28
+ featureColors
29
29
  };
30
30
 
31
31
  /* ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ */
32
32
  export { autoAnnotate };
33
33
  export { convertApELikeRegexToRegex };
34
34
  export { convertProteinSeqToDNAIupac };
35
- export * as bioData from './bioData';
36
- export { default as getAllInsertionsInSeqReads } from './getAllInsertionsInSeqReads';
37
- export { default as annotateSingleSeq } from './annotateSingleSeq';
38
- export { default as getDegenerateDnaStringFromAAString } from './getDegenerateDnaStringFromAAString';
39
- export { default as getDegenerateRnaStringFromAAString } from './getDegenerateRnaStringFromAAString';
40
- export { default as getVirtualDigest } from './getVirtualDigest';
41
- export { default as isEnzymeType2S } from './isEnzymeType2S';
42
- export { default as insertGapsIntoRefSeq } from './insertGapsIntoRefSeq';
43
- export { default as adjustBpsToReplaceOrInsert } from './adjustBpsToReplaceOrInsert';
44
- export { default as calculatePercentGC } from './calculatePercentGC';
45
- export { default as calculateTm } from './calculateTm';
46
- export { default as cutSequenceByRestrictionEnzyme } from './cutSequenceByRestrictionEnzyme';
47
- export { default as deleteSequenceDataAtRange } from './deleteSequenceDataAtRange';
48
- export { default as DNAComplementMap } from './DNAComplementMap';
49
- export { default as doesEnzymeChopOutsideOfRecognitionSite } from './doesEnzymeChopOutsideOfRecognitionSite';
50
- export { default as aliasedEnzymesByName } from './aliasedEnzymesByName';
51
- export { default as defaultEnzymesByName } from './defaultEnzymesByName';
52
- export { default as generateSequenceData } from './generateSequenceData';
53
- export { default as generateAnnotations } from './generateAnnotations';
54
- export { default as filterAminoAcidSequenceString } from './filterAminoAcidSequenceString';
55
- export { default as filterSequenceString } from './filterSequenceString';
56
- export { default as findNearestRangeOfSequenceOverlapToPosition } from './findNearestRangeOfSequenceOverlapToPosition';
57
- export { default as findOrfsInPlasmid } from './findOrfsInPlasmid';
58
- export { default as findSequenceMatches } from './findSequenceMatches';
59
- export { default as getAminoAcidDataForEachBaseOfDna } from './getAminoAcidDataForEachBaseOfDna';
60
- export { default as getAminoAcidFromSequenceTriplet } from './getAminoAcidFromSequenceTriplet';
61
- export { default as getAminoAcidStringFromSequenceString } from './getAminoAcidStringFromSequenceString';
62
- export { default as getCodonRangeForAASliver } from './getCodonRangeForAASliver';
63
- export { default as getComplementAminoAcidStringFromSequenceString } from './getComplementAminoAcidStringFromSequenceString';
64
- export { default as getComplementSequenceAndAnnotations } from './getComplementSequenceAndAnnotations';
65
- export { default as getComplementSequenceString } from './getComplementSequenceString';
66
- export { default as getCutsitesFromSequence } from './getCutsitesFromSequence';
67
- export { default as getCutsiteType } from './getCutsiteType';
68
- export { default as getInsertBetweenVals } from './getInsertBetweenVals';
69
- export { default as getLeftAndRightOfSequenceInRangeGivenPosition } from './getLeftAndRightOfSequenceInRangeGivenPosition';
70
- export { default as getOrfsFromSequence } from './getOrfsFromSequence';
71
- export { default as getOverlapBetweenTwoSequences } from './getOverlapBetweenTwoSequences';
72
- export { default as getPossiblePartsFromSequenceAndEnzymes } from './getPossiblePartsFromSequenceAndEnzymes';
73
- export { default as getReverseAminoAcidStringFromSequenceString } from './getReverseAminoAcidStringFromSequenceString';
74
- export { default as getReverseComplementAminoAcidStringFromSequenceString } from './getReverseComplementAminoAcidStringFromSequenceString';
75
- export { default as getReverseComplementAnnotation } from './getReverseComplementAnnotation';
76
- export { default as getReverseComplementSequenceAndAnnotations } from './getReverseComplementSequenceAndAnnotations';
77
- export { default as getReverseComplementSequenceString } from './getReverseComplementSequenceString';
78
- export { default as getReverseSequenceString } from './getReverseSequenceString';
79
- export { default as getSequenceDataBetweenRange } from './getSequenceDataBetweenRange';
80
- export { default as guessIfSequenceIsDnaAndNotProtein } from './guessIfSequenceIsDnaAndNotProtein';
81
- export { default as insertSequenceDataAtPosition } from './insertSequenceDataAtPosition';
82
- export { default as insertSequenceDataAtPositionOrRange } from './insertSequenceDataAtPositionOrRange';
83
- export { default as mapAnnotationsToRows } from './mapAnnotationsToRows';
84
- export { default as prepareCircularViewData } from './prepareCircularViewData';
85
- export { default as prepareRowData } from './prepareRowData';
86
- export { default as proteinAlphabet } from './proteinAlphabet';
87
- export { default as rotateSequenceDataToPosition } from './rotateSequenceDataToPosition';
88
- export { default as rotateBpsToPosition } from './rotateBpsToPosition';
89
- export { default as threeLetterSequenceStringToAminoAcidMap } from './threeLetterSequenceStringToAminoAcidMap';
90
- export { default as tidyUpSequenceData } from './tidyUpSequenceData';
91
- export { default as tidyUpAnnotation } from './tidyUpAnnotation';
92
- export { default as condensePairwiseAlignmentDifferences } from './condensePairwiseAlignmentDifferences';
93
- export { default as addGapsToSeqReads } from './addGapsToSeqReads';
94
- export { default as calculateNebTm } from './calculateNebTm';
95
- export { default as calculateNebTa } from './calculateNebTa';
96
- export { default as getDigestFragmentsForCutsites } from './getDigestFragmentsForCutsites';
97
- export { default as getDigestFragmentsForRestrictionEnzymes } from './getDigestFragmentsForRestrictionEnzymes';
98
- export { default as convertDnaCaretPositionOrRangeToAA } from './convertDnaCaretPositionOrRangeToAA';
99
- export { default as convertAACaretPositionOrRangeToDna } from './convertAACaretPositionOrRangeToDna';
100
- export { default as aminoAcidToDegenerateDnaMap } from './aminoAcidToDegenerateDnaMap';
101
- export { default as aminoAcidToDegenerateRnaMap } from './aminoAcidToDegenerateRnaMap';
102
- export { default as degenerateDnaToAminoAcidMap } from './degenerateDnaToAminoAcidMap';
103
- export { default as degenerateRnaToAminoAcidMap } from './degenerateRnaToAminoAcidMap';
104
- export { default as getMassOfAaString } from './getMassOfAaString';
105
- export { default as shiftAnnotationsByLen } from './shiftAnnotationsByLen';
106
- export { default as adjustAnnotationsToInsert } from './adjustAnnotationsToInsert';
35
+ export * as bioData from "./bioData";
36
+ export { default as getAllInsertionsInSeqReads } from "./getAllInsertionsInSeqReads";
37
+ export { default as annotateSingleSeq } from "./annotateSingleSeq";
38
+ export { default as getDegenerateDnaStringFromAAString } from "./getDegenerateDnaStringFromAAString";
39
+ export { default as getDegenerateRnaStringFromAAString } from "./getDegenerateRnaStringFromAAString";
40
+ export { default as getVirtualDigest } from "./getVirtualDigest";
41
+ export { default as isEnzymeType2S } from "./isEnzymeType2S";
42
+ export { default as insertGapsIntoRefSeq } from "./insertGapsIntoRefSeq";
43
+ export { default as adjustBpsToReplaceOrInsert } from "./adjustBpsToReplaceOrInsert";
44
+ export { default as calculatePercentGC } from "./calculatePercentGC";
45
+ export { default as calculateTm } from "./calculateTm";
46
+ export { default as cutSequenceByRestrictionEnzyme } from "./cutSequenceByRestrictionEnzyme";
47
+ export { default as deleteSequenceDataAtRange } from "./deleteSequenceDataAtRange";
48
+ export { default as DNAComplementMap } from "./DNAComplementMap";
49
+ export { default as doesEnzymeChopOutsideOfRecognitionSite } from "./doesEnzymeChopOutsideOfRecognitionSite";
50
+ export { default as aliasedEnzymesByName } from "./aliasedEnzymesByName";
51
+ export { default as defaultEnzymesByName } from "./defaultEnzymesByName";
52
+ export { default as generateSequenceData } from "./generateSequenceData";
53
+ export { default as generateAnnotations } from "./generateAnnotations";
54
+ export { default as filterSequenceString } from "./filterSequenceString";
55
+ export { default as findNearestRangeOfSequenceOverlapToPosition } from "./findNearestRangeOfSequenceOverlapToPosition";
56
+ export { default as findOrfsInPlasmid } from "./findOrfsInPlasmid";
57
+ export { default as findSequenceMatches } from "./findSequenceMatches";
58
+ export { default as getAminoAcidDataForEachBaseOfDna } from "./getAminoAcidDataForEachBaseOfDna";
59
+ export { default as getAminoAcidFromSequenceTriplet } from "./getAminoAcidFromSequenceTriplet";
60
+ export { default as getAminoAcidStringFromSequenceString } from "./getAminoAcidStringFromSequenceString";
61
+ export { default as getCodonRangeForAASliver } from "./getCodonRangeForAASliver";
62
+ export { default as getComplementAminoAcidStringFromSequenceString } from "./getComplementAminoAcidStringFromSequenceString";
63
+ export { default as getComplementSequenceAndAnnotations } from "./getComplementSequenceAndAnnotations";
64
+ export { default as getComplementSequenceString } from "./getComplementSequenceString";
65
+ export { default as getCutsitesFromSequence } from "./getCutsitesFromSequence";
66
+ export { default as getCutsiteType } from "./getCutsiteType";
67
+ export { default as getInsertBetweenVals } from "./getInsertBetweenVals";
68
+ export { default as getLeftAndRightOfSequenceInRangeGivenPosition } from "./getLeftAndRightOfSequenceInRangeGivenPosition";
69
+ export { default as getOrfsFromSequence } from "./getOrfsFromSequence";
70
+ export { default as getOverlapBetweenTwoSequences } from "./getOverlapBetweenTwoSequences";
71
+ export { default as getPossiblePartsFromSequenceAndEnzymes } from "./getPossiblePartsFromSequenceAndEnzymes";
72
+ export { default as getReverseAminoAcidStringFromSequenceString } from "./getReverseAminoAcidStringFromSequenceString";
73
+ export { default as getReverseComplementAminoAcidStringFromSequenceString } from "./getReverseComplementAminoAcidStringFromSequenceString";
74
+ export { default as getReverseComplementAnnotation } from "./getReverseComplementAnnotation";
75
+ export { default as getReverseComplementSequenceAndAnnotations } from "./getReverseComplementSequenceAndAnnotations";
76
+ export { default as getReverseComplementSequenceString } from "./getReverseComplementSequenceString";
77
+ export { default as getReverseSequenceString } from "./getReverseSequenceString";
78
+ export { default as getSequenceDataBetweenRange } from "./getSequenceDataBetweenRange";
79
+ export { default as guessIfSequenceIsDnaAndNotProtein } from "./guessIfSequenceIsDnaAndNotProtein";
80
+ export { default as insertSequenceDataAtPosition } from "./insertSequenceDataAtPosition";
81
+ export { default as insertSequenceDataAtPositionOrRange } from "./insertSequenceDataAtPositionOrRange";
82
+ export { default as mapAnnotationsToRows } from "./mapAnnotationsToRows";
83
+ export { default as prepareCircularViewData } from "./prepareCircularViewData";
84
+ export { default as prepareRowData } from "./prepareRowData";
85
+ export { default as proteinAlphabet } from "./proteinAlphabet";
86
+ export { default as rotateSequenceDataToPosition } from "./rotateSequenceDataToPosition";
87
+ export { default as rotateBpsToPosition } from "./rotateBpsToPosition";
88
+ export { default as threeLetterSequenceStringToAminoAcidMap } from "./threeLetterSequenceStringToAminoAcidMap";
89
+ export { default as tidyUpSequenceData } from "./tidyUpSequenceData";
90
+ export { default as tidyUpAnnotation } from "./tidyUpAnnotation";
91
+ export { default as condensePairwiseAlignmentDifferences } from "./condensePairwiseAlignmentDifferences";
92
+ export { default as addGapsToSeqReads } from "./addGapsToSeqReads";
93
+ export { default as calculateNebTm } from "./calculateNebTm";
94
+ export { default as calculateNebTa } from "./calculateNebTa";
95
+ export { default as getDigestFragmentsForCutsites } from "./getDigestFragmentsForCutsites";
96
+ export { default as getDigestFragmentsForRestrictionEnzymes } from "./getDigestFragmentsForRestrictionEnzymes";
97
+ export { default as convertDnaCaretPositionOrRangeToAA } from "./convertDnaCaretPositionOrRangeToAA";
98
+ export { default as convertAACaretPositionOrRangeToDna } from "./convertAACaretPositionOrRangeToDna";
99
+ export { default as aminoAcidToDegenerateDnaMap } from "./aminoAcidToDegenerateDnaMap";
100
+ export { default as aminoAcidToDegenerateRnaMap } from "./aminoAcidToDegenerateRnaMap";
101
+ export { default as degenerateDnaToAminoAcidMap } from "./degenerateDnaToAminoAcidMap";
102
+ export { default as degenerateRnaToAminoAcidMap } from "./degenerateRnaToAminoAcidMap";
103
+ export { default as getMassOfAaString } from "./getMassOfAaString";
104
+ export { default as shiftAnnotationsByLen } from "./shiftAnnotationsByLen";
105
+ export { default as adjustAnnotationsToInsert } from "./adjustAnnotationsToInsert";
package/src/index.test.js CHANGED
@@ -3,8 +3,7 @@ import fs from "fs";
3
3
 
4
4
  describe("index.js", () => {
5
5
  it(`should export all functions defined`, () => {
6
- return new Promise((resolve) => {
7
-
6
+ return new Promise(resolve => {
8
7
  fs.readdir(__dirname, (err, files) => {
9
8
  let passes = true;
10
9
  files.forEach(file => {
@@ -29,10 +28,12 @@ describe("index.js", () => {
29
28
  }
30
29
  });
31
30
  if (!passes) {
32
- throw new Error("Please make sure to export (or ignore) each file! Update index.js to export the file");
31
+ throw new Error(
32
+ "Please make sure to export (or ignore) each file! Update index.js to export the file"
33
+ );
33
34
  }
34
35
  resolve();
35
36
  });
36
- })
37
+ });
37
38
  });
38
39
  });
@@ -21,7 +21,7 @@ export default function insertGapsIntoRefSeq(refSeq, seqReads) {
21
21
  }
22
22
  // refSeqWithGaps is a string "GGGA--GA-C--ACC"
23
23
  return refSeqWithGaps.join("");
24
- };
24
+ }
25
25
 
26
26
  // allInsertionsInSeqReads.forEach(insertion => {
27
27
  // // adding gap at the bp pos of insertion
@@ -1,6 +1,5 @@
1
1
  //tnr: half finished test.
2
2
 
3
-
4
3
  import chai from "chai";
5
4
  import chaiSubset from "chai-subset";
6
5
 
@@ -40,7 +39,10 @@ describe("insertSequenceData", () => {
40
39
  {
41
40
  start: 0,
42
41
  end: 9,
43
- locations: [{ start: 0, end: 3 }, { start: 5, end: 9 }]
42
+ locations: [
43
+ { start: 0, end: 3 },
44
+ { start: 5, end: 9 }
45
+ ]
44
46
  }
45
47
  ]
46
48
  };
@@ -1,10 +1,10 @@
1
- import {getRangeLength} from "@teselagen/range-utils";
2
- import {map, cloneDeep} from "lodash";
1
+ import { getRangeLength } from "@teselagen/range-utils";
2
+ import { map, cloneDeep } from "lodash";
3
3
  import convertDnaCaretPositionOrRangeToAa from "./convertDnaCaretPositionOrRangeToAA";
4
4
  import rotateSequenceDataToPosition from "./rotateSequenceDataToPosition";
5
- import {adjustRangeToDeletionOfAnotherRange} from "@teselagen/range-utils";
5
+ import { adjustRangeToDeletionOfAnotherRange } from "@teselagen/range-utils";
6
6
  import tidyUpSequenceData from "./tidyUpSequenceData";
7
- import {modifiableTypes} from "./annotationTypes";
7
+ import { modifiableTypes } from "./annotationTypes";
8
8
  import adjustBpsToReplaceOrInsert from "./adjustBpsToReplaceOrInsert";
9
9
  import adjustAnnotationsToInsert from "./adjustAnnotationsToInsert";
10
10
 
@@ -164,7 +164,7 @@ export default function insertSequenceDataAtPositionOrRange(
164
164
  );
165
165
  }
166
166
  return newSequenceData;
167
- };
167
+ }
168
168
 
169
169
  function adjustAnnotationsToDelete(annotationsToBeAdjusted, range, maxLength) {
170
170
  return map(annotationsToBeAdjusted, annotation => {
@@ -1,9 +1,8 @@
1
1
  //tnr: half finished test.
2
2
 
3
-
4
3
  import chai from "chai";
5
4
 
6
- import {getRangeLength} from "@teselagen/range-utils";
5
+ import { getRangeLength } from "@teselagen/range-utils";
7
6
  import assert from "assert";
8
7
  import chaiSubset from "chai-subset";
9
8
 
@@ -452,17 +451,7 @@ describe("insertSequenceData", () => {
452
451
  postInsertSeq.chromatogramData.baseCalls.length.should.equal(8);
453
452
  postInsertSeq.chromatogramData.baseTraces.length.should.equal(8);
454
453
  postInsertSeq.chromatogramData.baseTraces[4].aTrace.should.deep.equal([
455
- 0,
456
- 0,
457
- 0,
458
- 0,
459
- 0,
460
- 0,
461
- 0,
462
- 0,
463
- 0,
464
- 0,
465
- 0
454
+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0
466
455
  ]);
467
456
  });
468
457
  it("properly inserts into chromatogramData, keeping the chromatogramData intact if the insert length is the same length as the selection range", () => {
@@ -538,10 +527,7 @@ describe("insertSequenceData", () => {
538
527
  ]);
539
528
  postInsertSeq.chromatogramData.baseTraces.length.should.equal(7);
540
529
  postInsertSeq.chromatogramData.baseTraces[4].aTrace.should.deep.equal([
541
- 0,
542
- 2,
543
- 6,
544
- 8
530
+ 0, 2, 6, 8
545
531
  ]);
546
532
  });
547
533
  });
@@ -1,3 +1,3 @@
1
1
  export default function isEnzymeType2S(e) {
2
2
  return e.site.length < e.topSnipOffset || e.site.length < e.bottomSnipOffset;
3
- };
3
+ }
@@ -1,8 +1,8 @@
1
- import {each, forEach, startsWith, filter} from "lodash";
1
+ import { each, forEach, startsWith, filter } from "lodash";
2
2
 
3
3
  import {
4
4
  getYOffsetForPotentiallyCircularRange,
5
- splitRangeIntoTwoPartsIfItIsCircular,
5
+ splitRangeIntoTwoPartsIfItIsCircular
6
6
  } from "@teselagen/range-utils";
7
7
 
8
8
  export default function mapAnnotationsToRows(
@@ -72,7 +72,7 @@ export default function mapAnnotationsToRows(
72
72
  );
73
73
  });
74
74
  return annotationsToRowsMap;
75
- };
75
+ }
76
76
 
77
77
  function mapAnnotationToRows({
78
78
  annotation,
@@ -1,8 +1,6 @@
1
-
2
-
3
1
  import chai from "chai";
4
2
 
5
- import {expect} from "chai";
3
+ import { expect } from "chai";
6
4
  import chaiSubset from "chai-subset";
7
5
  import mapAnnotationsToRows from "./mapAnnotationsToRows.js";
8
6
  chai.use(chaiSubset);