diff --git a/.komment/00000.json b/.komment/00000.json index 7ee5d63..5bc2ce9 100644 --- a/.komment/00000.json +++ b/.komment/00000.json @@ -4,12 +4,12 @@ "path": "src/index.ts", "content": { "structured": { - "description": "A DocumentStore class that manages adding, retrieving, and updating documents in a specified namespace. It also provides methods for generating high-quality documentation and outputting chunks of code based on the given content. The class uses various packages such as `passing-api` and `highland` to perform its functions.", + "description": "A `DocumentStore` class for managing adding, retrieving, and updating documents in a specified folder. It includes functions for loading and summarizing documents, as well as methods for updating files and generating high-quality documentation. The code also uses various types and packages such as `PassType`, `GetRemote`, `StructuredFile`, and `Summarry`. Overall, the code provides a flexible and structured approach to managing and organizing documents.", "items": [ { - "id": "ee29f824-943b-c1b4-964f-bf43e6e55b2f", + "id": "b3dde4d0-0c04-e6b8-f94b-b717b02da80a", "ancestors": [], - "description": "Provides a centralized storage and management system for files, handling chunking, loading, and metadata for high-quality documentation generation.", + "description": "Stores and manages code documentation, providing an interface for loading, updating, and querying the content.", "interfaces": [ "IDocumentStore" ], @@ -19,12 +19,12 @@ { "name": "CHUNK_SIZE", "type_name": "number", - "description": "5, which represents the size of each chunk in bytes for storing and retrieving files from a remote store." + "description": "512 by default, which defines the size of each chunk in the code storage." }, { "name": "namespace", "type_name": "string", - "description": "A name or identifier for the document store, which can be used to refer to it from other parts of the code." + "description": "Required. It provides a unique identifier for the code document store, which is used to generate high-quality documentation." }, { "name": "meta", @@ -61,7 +61,7 @@ } ] }, - "description": "Used to store high-quality documentation-related metadata." + "description": "Used to store information about the document" }, { "name": "metaTemplate", @@ -74,22 +74,22 @@ "any" ] }, - "description": "Used to provide a template for generating high-quality documentation for code." + "description": "Used to provide information about the metadata of the document." }, { "name": "lookup", "type_name": "string[][]", - "description": "Used to store a list of sub-arrays, where each sub-array contains a chunk index and a file index within that chunk." + "description": "Used to store a list of file paths that correspond to chunks of code, keyed by chunk index." }, { "name": "chunks", "type_name": "StructuredFile[][]", - "description": "Used to store the chunks of content from the original code, allowing for efficient retrieval of files within a particular chunk." + "description": "Used to store chunks of content." }, { "name": "content", "type_name": "StructuredFile[]", - "description": "Used to store the contents of the documents." + "description": "Responsible for storing the contents of the document chunks in the internal array." }, { "name": "status", @@ -117,7 +117,7 @@ } ] }, - "description": "Used to store information about the status of the document store" + "description": "Used to track the state of the document store, including whether summary was last updated and whether chunks were loaded." } ], "name": "DocumentStore", @@ -133,38 +133,38 @@ "docLength": null }, { - "id": "e39b354b-a990-7492-9a47-9501729db645", + "id": "8708e7e0-9cfd-63bb-c744-97510241eaec", "ancestors": [ - "ee29f824-943b-c1b4-964f-bf43e6e55b2f" + "b3dde4d0-0c04-e6b8-f94b-b717b02da80a" ], - "description": "Sets up instance variables such as `CHUNK_SIZE`, `namespace`, `getRemote`, and `meta`, as well as initializing objects such as `lookup`, `chunks`, and `content`.", + "description": "Sets up various properties and variables required to store and manage documents, including the namespace, getRemote method, meta data, and chunk-related parameters.", "params": [ { "name": "namespace", "type_name": "string", "optional": false, - "description": "Required to identify the name of a specific data store, such as a database or file system, where the chunked data will be stored.", + "description": "Required for the construction of the Document Store constructor. It represents the unique name or identifier of the document store, which can be used to differentiate it from other document stores in a given environment.", "default_value": null }, { "name": "getRemote", "type_name": "(...args: any[]) => Promise>", "optional": false, - "description": "Used to fetch data from a remote source, such as an API or database, and return it as a promise.", + "description": "Used to retrieve data remotely.", "default_value": null }, { "name": "additionalMeta", "type_name": "Record", "optional": true, - "description": "Used to store additional metadata about the document that can be used for customization or tracking purposes.", + "description": "Used to provide additional metadata for the document, such as version number or creation date.", "default_value": "{}" } ], "usage": { "language": "typescript", - "code": "const documentStore = new DocumentStore(\n \"example-namespace\",\n async (...args) => {\n // getRemote implementation goes here\n },\n {\n version: \"1.0.0\",\n created_at: new Date(),\n updated_at: new Date(),\n additionalMeta: {},\n }\n);\n", - "description": "\nThis code instantiates a DocumentStore object with the namespace \"example-namespace\" and provides an implementation for getRemote method. The additionalMeta parameter is an optional object that can be used to add additional metadata to the document store." + "code": "const namespace = \"my-namespace\";\nconst getRemoteMethod = async (...args) => { /* implementation of remote method */ };\nconst additionalMeta = { /* metadata object */ };\n\n// create a new instance of DocumentStore with the provided parameters\nconst documentStore = new DocumentStore(namespace, getRemoteMethod, additionalMeta);\n", + "description": "" }, "name": null, "location": { @@ -182,23 +182,23 @@ "docLength": 12 }, { - "id": "582c42b2-5c3c-beac-3548-cb27e24f1477", + "id": "b532784a-8bc4-34bd-b845-b66a3613aa9e", "ancestors": [ - "ee29f824-943b-c1b4-964f-bf43e6e55b2f" + "b3dde4d0-0c04-e6b8-f94b-b717b02da80a" ], - "description": "Updates the `updated_at` metadata field of the object, by setting it to the provided `Date` value.", + "description": "Updates the `updated_at` metadata field of an object, by setting it to the provided `Date` value.", "params": [ { "name": "updated_at", "default_value": null, "optional": false, "type_name": "Date", - "description": "Used to update the `updated_at` metadata field of an entity." + "description": "Used to update the `updated_at` metadata of an object." } ], "usage": { "language": "typescript", - "code": "const store = new DocumentStore();\nstore.setUpdatedAt(new Date()); // Update the updated_at field with current time.\n", + "code": "// Initialize DocumentStore with remote function and integration object\nconst documentStore = new DocumentStore(getRemote, integration);\n\n// Set updated at time\ndocumentStore.setUpdatedAt(new Date());\n", "description": "" }, "name": "setUpdatedAt", @@ -217,15 +217,15 @@ "docLength": 7 }, { - "id": "74b63f05-a80a-bcb1-2c4b-b81d868bed7d", + "id": "47940390-1fbd-bea2-6840-795713d648e5", "ancestors": [ - "ee29f824-943b-c1b4-964f-bf43e6e55b2f" + "b3dde4d0-0c04-e6b8-f94b-b717b02da80a" ], - "description": "Retrieves and updates a summary of documents stored in the store, including metadata and chunk information.", + "description": "Retrieves and updates the summary data for the documents stored in the local store, using remote information if available.", "params": [], "usage": { "language": "typescript", - "code": "const documentStore = new DocumentStore(getRemote, integration);\nawait documentStore.loadSummary();\n", + "code": "const documentStore = new DocumentStore(getRemote, integration);\ndocumentStore.loadSummary();\n", "description": "" }, "name": "loadSummary", @@ -244,12 +244,12 @@ "docLength": 4 }, { - "id": "9b4daeca-55a7-9192-c945-b8561c2df96c", + "id": "ad84e589-f4d3-dc8d-1945-6a28b1dade93", "ancestors": [ - "ee29f824-943b-c1b4-964f-bf43e6e55b2f", - "74b63f05-a80a-bcb1-2c4b-b81d868bed7d" + "b3dde4d0-0c04-e6b8-f94b-b717b02da80a", + "47940390-1fbd-bea2-6840-795713d648e5" ], - "description": "Updates the `this.meta` object with values from `summary.meta` or the original value if `summary.meta` is null or undefined.", + "description": "Updates the `this.meta` object's property values based on \nthe `summary.meta` object and an optional default value.", "name": null, "location": { "start": 121, @@ -263,15 +263,15 @@ "docLength": null }, { - "id": "6a2161bc-1e90-17bc-aa44-ce1fb0b6a21c", + "id": "12f01fee-84ea-94bd-f242-d6aebf66a20f", "ancestors": [ - "ee29f824-943b-c1b4-964f-bf43e6e55b2f" + "b3dde4d0-0c04-e6b8-f94b-b717b02da80a" ], - "description": "Asyncily loads chunks of data from storage based on a provided list of chunk indices, setting the `chunks` property to `true` upon completion.", + "description": "Retrieves and loads chunks of data from the storage, based on their indices, and sets the `chunks` property to `true`.", "params": [], "usage": { "language": "typescript", - "code": "const docStore = new DocumentStore(getRemote, integration);\n\nawait docStore.load();\n", + "code": "const documentStore = new DocumentStore(getRemote, integration);\ndocumentStore.load().then(() => {\n // Use the loaded content here\n});\n", "description": "" }, "name": "load", @@ -290,23 +290,23 @@ "docLength": 3 }, { - "id": "73fa576b-8ba0-f488-414c-07a1fa72c6e5", + "id": "3b5d1e3f-968d-ed95-9447-ca0dd7bd38cc", "ancestors": [ - "ee29f824-943b-c1b4-964f-bf43e6e55b2f" + "b3dde4d0-0c04-e6b8-f94b-b717b02da80a" ], - "description": "Updates the metadata of the instance by combining its current metadata with additional metadata provided as an argument, assigning the resulting object to the `meta` property.", + "description": "Updates the metadata of an object by merging the existing metadata with additional metadata provided as an argument.", "params": [ { "name": "additionalMeta", "default_value": null, "optional": false, "type_name": "Record", - "description": "Used to provide additional metadata to update the existing metadata of the object." + "description": "Used to add or update metadata for the component." } ], "usage": { "language": "typescript", - "code": "const docStore = new DocumentStore(getRemote, integration);\ndocStore.updateMetadata({ version: '1.0.0', created_at: Date.now() });\n", + "code": "const documentStore = new DocumentStore(getRemote, integration);\ndocumentStore.updateMetadata({ version: '1.0', created_at: new Date() });\n", "description": "" }, "name": "updateMetadata", @@ -322,27 +322,27 @@ "docLength": null }, { - "id": "0709d86a-5ad4-c5a8-a349-cd6516f040be", + "id": "bb016c57-6713-9b8c-7a41-2301a0fc173b", "ancestors": [ - "ee29f824-943b-c1b4-964f-bf43e6e55b2f" + "b3dde4d0-0c04-e6b8-f94b-b717b02da80a" ], - "description": "Asyncously checks if a chunk is loaded, retrieves it from the server if not, and appends it to the internal content and chunks arrays if successful.", + "description": "Loads a chunk of the document from the server and adds it to the document's content and chunks array if successful.", "params": [ { "name": "chunkIndex", "default_value": null, "optional": false, "type_name": "number", - "description": "Used to identify the specific chunk being loaded." + "description": "Used to represent the index of the chunk being loaded, which serves as a reference for checking if the chunk has already been loaded or not." } ], "returns": { "type_name": "Promise", - "description": "True if the chunk was successfully loaded and false otherwise." + "description": "Resolved when the chunk is loaded successfully, and rejected when there is an error." }, "usage": { "language": "typescript", - "code": "const documentStore = new DocumentStore();\ndocumentStore.getRemote = async (key) => {\n // do some magic to retrieve the data from a remote location\n};\nawait documentStore.loadChunk(0);\n", + "code": "const store = new DocumentStore(getRemote);\nconst chunkLoaded = await store.loadChunk(100);\n", "description": "" }, "name": "loadChunk", @@ -361,28 +361,28 @@ "docLength": 11 }, { - "id": "c8f89bf8-783d-0e93-f44f-372598c56e8c", + "id": "87a9bdaf-5b4c-3dbd-d24b-004065eab39a", "ancestors": [ - "ee29f824-943b-c1b4-964f-bf43e6e55b2f" + "b3dde4d0-0c04-e6b8-f94b-b717b02da80a" ], - "description": "Retrieves a file from the store based on its path, loading the necessary chunks and files if not already loaded. It returns the file or `null` if not found.", + "description": "Retrieves a file from the store based on its path, checking if it is already loaded and returning it if found, or loading it if necessary.", "params": [ { "name": "path", "default_value": null, "optional": false, "type_name": "string", - "description": "Used to represent the file path that the function will check for existence and load if necessary." + "description": "Used to represent the file path that needs to be retrieved." } ], "returns": { "type_name": "Promise", - "description": "A promise that resolves to a StructuredFile object or null if the file cannot be found in the specified chunk." + "description": "A promise that resolves to a StructuredFile object or null if the file is not found in the specified chunk." }, "usage": { "language": "typescript", - "code": "const getFile = async (path: string): Promise => {\n const store = new DocumentStore(getRemote, integration);\n // calling method getFile to access structured file\n await store.getFile('some/path'); \n}\n", - "description": "\nThis calls the `getFile` function of the `DocumentStore` class using the `getRemote` and `integration` methods. The `getFile` function then uses the `this` context to call other methods in the class such as `getChunkFileIsIn`, `isChunkLoaded`, `loadChunk`, `getFileIndexInChunk`, and `chunks`." + "code": "const documentStore = new DocumentStore(getRemote, integration);\ndocumentStore.CHUNK_SIZE = 10;\ndocumentStore.namespace = 'example';\nawait documentStore.loadSummary();\nconst structuredFile = await documentStore.getFile('path/to/file');\n", + "description": "" }, "name": "getFile", "location": { @@ -400,23 +400,23 @@ "docLength": 10 }, { - "id": "0a32c675-0a38-6ea3-fc44-48093d5f2b1c", + "id": "881a598d-88b7-a19d-4242-87421a2ee841", "ancestors": [ - "ee29f824-943b-c1b4-964f-bf43e6e55b2f" + "b3dde4d0-0c04-e6b8-f94b-b717b02da80a" ], - "description": "Adds a new document path to the end of an existing lookup subtable or creates a new table if the last one is full, preserving the chunk size.", + "description": "Updates the lookup subtable based on the provided path. If the last subtable is full, create a new one; otherwise, append the path to the existing subtable.", "params": [ { "name": "path", "default_value": null, "optional": false, "type_name": "string", - "description": "Used to add a new element to the end of the lookup subtable." + "description": "Intended to represent a path to add to the end of the lookup table." } ], "usage": { "language": "typescript", - "code": "const docStore = new DocumentStore(getRemote, integration);\ndocStore.addToEndOfLookup(\"path/to/file\");\n", + "code": "const docStore = new DocumentStore(getRemote, integration);\ndocStore.addToEndOfLookup(\"path\");\n", "description": "" }, "name": "addToEndOfLookup", @@ -435,23 +435,23 @@ "docLength": 6 }, { - "id": "6a710976-4226-8098-5741-7cc047e44144", + "id": "5a49562b-8589-0c99-944e-e80e82717313", "ancestors": [ - "ee29f824-943b-c1b4-964f-bf43e6e55b2f" + "b3dde4d0-0c04-e6b8-f94b-b717b02da80a" ], - "description": "Manages the chunking of files based on file size, creating new chunks if the last one is full or appending to it otherwise.", + "description": "Adds a new file to the end of an array of chunks if the last one is full or if the current chunk is not full, and pushes it to the appropriate position in the chunk array.", "params": [ { "name": "file", "default_value": null, "optional": false, "type_name": "StructuredFile", - "description": "Used to add new files to an array of chunks for processing." + "description": "Passed to add a file to an array of files, called chunks, within a larger data structure." } ], "usage": { "language": "typescript", - "code": "let docStore = new DocumentStore(getRemote, integration);\ndocStore.addToEndOfChunks(file);\n", + "code": "const documentStore = new DocumentStore(getRemote, integration);\n// addToEndOfChunks(file)\ndocumentStore.addToEndOfChunks(structuredFile);\n\n", "description": "" }, "name": "addToEndOfChunks", @@ -470,27 +470,27 @@ "docLength": 10 }, { - "id": "99e120cb-0aef-cdb1-ac46-ebae4d34daee", + "id": "e9b6e47e-5590-5d85-b745-4c6cceae3657", "ancestors": [ - "ee29f824-943b-c1b4-964f-bf43e6e55b2f" + "b3dde4d0-0c04-e6b8-f94b-b717b02da80a" ], - "description": "Allows adding a file to the collection of documents, checking for file existence and properly updating the content array if successful.", + "description": "Adds a file to the collection of stored files. It first checks if the `status.chunks` property is set and if the input file exists at its path. If so, it updates the file in the collection and returns `true`. Otherwise, it appends the file to the end of the lookup table and chunks list and returns `true`.", "params": [ { "name": "file", "default_value": null, "optional": false, "type_name": "StructuredFile", - "description": "Used to represent a file that needs to be added to the content manager's chunks or lookups." + "description": "Used to represent a file that is being added to the content library." } ], "returns": { "type_name": "boolean", - "description": "True if the file was successfully added to the content array and false otherwise." + "description": "`true` if the file was successfully added to the content, and `false` otherwise." }, "usage": { "language": "typescript", - "code": "let documentStore = new DocumentStore({ getRemote, integration });\ndocumentStore.addFile(file); // where file is a StructuredFile object with path and content properties\n", + "code": "// Create new instance of DocumentStore\nconst documentStore = new DocumentStore(getRemote, integration);\n// Add file to store\ndocumentStore.addFile({\n path: \"path/to/file\",\n content: \"file content\"\n});\n// Update existing file in store\ndocumentStore.updateFile(\"existing-file\", {\n path: \"updated-file-path\",\n content: \"updated-file-content\"\n});\n", "description": "" }, "name": "addFile", @@ -509,28 +509,28 @@ "docLength": 10 }, { - "id": "422a10ed-1dce-62b3-584e-99e4d60678e0", + "id": "2b1d9107-8359-9abb-df42-c6b4e2ebf6ac", "ancestors": [ - "ee29f824-943b-c1b4-964f-bf43e6e55b2f" + "b3dde4d0-0c04-e6b8-f94b-b717b02da80a" ], - "description": "Updates a file in the store by checking its existence, loading it if necessary, and storing it in the correct chunk and index position.", + "description": "Updates a file in the store by checking if it exists, loading it if necessary, and storing it in the appropriate chunk and index position.", "params": [ { "name": "file", "default_value": null, "optional": false, "type_name": "StructuredFile", - "description": "Used to represent a file within the application's data structure. Its purpose is to provide a reference to the file that needs to be updated." + "description": "Used to represent a file that needs to be updated or added to the content library." } ], "returns": { "type_name": "Promise", - "description": "Ether true or false depending on whether the file was successfully updated or not." + "description": "Whether the file was updated successfully or not." }, "usage": { "language": "typescript", - "code": "const documentStore = new DocumentStore(getRemote, integration);\ndocumentStore.updateFile(file); // file is a StructuredFile object that contains file metadata and content.\n", - "description": "\nThe updateFile method takes a single argument of type StructuredFile, which is a class that represents a file with metadata and content. It then updates the file in the DocumentStore's internal arrays and objects." + "code": "const documentStore = new DocumentStore(getRemote, integration);\ndocumentStore.updateFile({\n path: \"path/to/file\",\n content: \"New content\"\n});\n", + "description": "" }, "name": "updateFile", "location": { @@ -548,19 +548,19 @@ "docLength": 10 }, { - "id": "fc07d4eb-2680-abbe-ef48-d49763b88239", + "id": "d42d5f63-ba14-f592-9f49-57a104d8a3a5", "ancestors": [ - "ee29f824-943b-c1b4-964f-bf43e6e55b2f" + "b3dde4d0-0c04-e6b8-f94b-b717b02da80a" ], - "description": "Returns an object containing the `meta` and `lookup` properties, which are likely used to store and retrieve metadata and data for documents managed by the class.", + "description": "Returns an object containing `meta` and `lookup` properties, which are presumably used to summarize or represent the contents of the document store.", "params": [], "returns": { "type_name": "Summary", - "description": "An object containing two properties: `meta` and `lookup`." + "description": "An object consisting of two properties: `meta` and `lookup`." }, "usage": { "language": "typescript", - "code": "const documentStore = new DocumentStore();\ndocumentStore.getRemote(/* params */);\ndocumentStore.outputSummary();\n", + "code": "const documentStore = new DocumentStore(getRemote, integration);\ndocumentStore.outputSummary();\n", "description": "" }, "name": "outputSummary", @@ -579,20 +579,20 @@ "docLength": 6 }, { - "id": "0e0d8eb1-bdf8-109f-7a4b-5956cfb16085", + "id": "411bd430-23b2-c3b5-1048-a4206864644f", "ancestors": [ - "ee29f824-943b-c1b4-964f-bf43e6e55b2f" + "b3dde4d0-0c04-e6b8-f94b-b717b02da80a" ], - "description": "Generates and returns an object containing chunks of the original document,keyed by their chunk paths.", + "description": "Generates an object with chunk-related metadata and content for each chunk in the document. The method iterates through the document's content, slices it into chunks, and assigns a unique identifier to each chunk.", "params": [], "returns": { "type_name": "Record", - "description": "An object containing chunk data." + "description": "An object where each key is a chunk path and the corresponding value is the contents of that chunk." }, "usage": { "language": "typescript", - "code": "const documentStore = new DocumentStore();\ndocumentStore.getRemote = async () => {\n const response = await fetch('https://api.example.com/');\n return JSON.parse(response);\n};\nawait documentStore.initialize('integration_name', '1.0.0');\nconst chunks = documentStore.outputChunks();\n", - "description": "" + "code": "const docStore = new DocumentStore({getRemote, integration});\nconst outputChunks = docStore.outputChunks();\n// Do something with the chunked content\n", + "description": "\nThe end user can then use the `outputChunks()` method to get the chunks of the content in the document store and process them as needed. The method returns a record that contains an entry for each chunk, where the key is the path of the chunk and the value is the chunk itself." }, "name": "outputChunks", "location": { diff --git a/.komment/komment.json b/.komment/komment.json index d8349fe..3f27a5c 100644 --- a/.komment/komment.json +++ b/.komment/komment.json @@ -1,7 +1,7 @@ { "meta": { "version": "1", - "updated_at": "2024-07-12T09:07:47.272Z", + "updated_at": "2024-07-12T13:13:07.524Z", "created_at": "2024-07-10T16:34:39.374Z", "pipelines": [ "c089e2e8-dd67-4bff-afef-c8f0f6b8a931", @@ -23,7 +23,8 @@ "344dea1f-37c5-4706-b964-90ffeed56096", "c355b024-a5e5-4eea-b745-fd2482d6e5c6", "532c71df-781e-414b-98ad-8f67da7424a6", - "5c864a2d-0ee3-4c2e-8392-299b19565254" + "5c864a2d-0ee3-4c2e-8392-299b19565254", + "e47a1503-66d2-402a-a043-4b6b405c390f" ] }, "lookup": [ diff --git a/src/index.ts b/src/index.ts index 6db163a..7f97adb 100644 --- a/src/index.ts +++ b/src/index.ts @@ -20,8 +20,8 @@ const CHUNK_SIZE = 40; const DOCUMENT_STORE_VERSION = "1"; /** - * @description Provides a centralized storage and management system for files, - * handling chunking, loading, and metadata for high-quality documentation generation. + * @description Stores and manages code documentation, providing an interface for + * loading, updating, and querying the content. * * @implements {IDocumentStore} */ @@ -45,18 +45,19 @@ class DocumentStore implements IDocumentStore { }; /** - * @description Sets up instance variables such as `CHUNK_SIZE`, `namespace`, - * `getRemote`, and `meta`, as well as initializing objects such as `lookup`, `chunks`, - * and `content`. + * @description Sets up various properties and variables required to store and manage + * documents, including the namespace, getRemote method, meta data, and chunk-related + * parameters. * - * @param {string} namespace - Required to identify the name of a specific data store, - * such as a database or file system, where the chunked data will be stored. + * @param {string} namespace - Required for the construction of the Document Store + * constructor. It represents the unique name or identifier of the document store, + * which can be used to differentiate it from other document stores in a given environment. * - * @param {(...args: any[]) => Promise>} getRemote - Used to fetch - * data from a remote source, such as an API or database, and return it as a promise. + * @param {(...args: any[]) => Promise>} getRemote - Used to retrieve + * data remotely. * - * @param {Record} additionalMeta - Used to store additional metadata - * about the document that can be used for customization or tracking purposes. + * @param {Record} additionalMeta - Used to provide additional metadata + * for the document, such as version number or creation date. */ constructor( namespace: string, @@ -86,18 +87,18 @@ class DocumentStore implements IDocumentStore { } /** - * @description Updates the `updated_at` metadata field of the object, by setting it + * @description Updates the `updated_at` metadata field of an object, by setting it * to the provided `Date` value. * - * @param {Date} updated_at - Used to update the `updated_at` metadata field of an entity. + * @param {Date} updated_at - Used to update the `updated_at` metadata of an object. */ setUpdatedAt = (updated_at: Date) => { this.meta.updated_at = updated_at; }; /** - * @description Retrieves and updates a summary of documents stored in the store, - * including metadata and chunk information. + * @description Retrieves and updates the summary data for the documents stored in + * the local store, using remote information if available. */ loadSummary = async () => { let summary: Summary = { @@ -126,8 +127,8 @@ class DocumentStore implements IDocumentStore { this.meta.created_at = summary?.meta?.created_at || new Date(); this.meta.updated_at = summary?.meta?.updated_at || new Date(); Object.entries(this.metaTemplate).forEach(([key, value]) => { - // Updates the `this.meta` object with values from `summary.meta` or the original - // value if `summary.meta` is null or undefined. + // Updates the `this.meta` object's property values based on + // the `summary.meta` object and an optional default value. this.meta[key] = summary?.meta?.[key] ?? value; }); @@ -136,8 +137,8 @@ class DocumentStore implements IDocumentStore { }; /** - * @description Asyncily loads chunks of data from storage based on a provided list - * of chunk indices, setting the `chunks` property to `true` upon completion. + * @description Retrieves and loads chunks of data from the storage, based on their + * indices, and sets the `chunks` property to `true`. */ load = async () => { if (!this.status.summary) { @@ -160,12 +161,11 @@ class DocumentStore implements IDocumentStore { `.${this.namespace}/${this.namespace}.json`; /** - * @description Updates the metadata of the instance by combining its current metadata - * with additional metadata provided as an argument, assigning the resulting object - * to the `meta` property. + * @description Updates the metadata of an object by merging the existing metadata + * with additional metadata provided as an argument. * - * @param {Record} additionalMeta - Used to provide additional metadata - * to update the existing metadata of the object. + * @param {Record} additionalMeta - Used to add or update metadata for + * the component. */ updateMetadata = (additionalMeta: Record) => { this.meta = { @@ -181,12 +181,15 @@ class DocumentStore implements IDocumentStore { this.chunks[chunkIndex]?.length > 0; /** - * @description Asyncously checks if a chunk is loaded, retrieves it from the server - * if not, and appends it to the internal content and chunks arrays if successful. + * @description Loads a chunk of the document from the server and adds it to the + * document's content and chunks array if successful. * - * @param {number} chunkIndex - Used to identify the specific chunk being loaded. + * @param {number} chunkIndex - Used to represent the index of the chunk being loaded, + * which serves as a reference for checking if the chunk has already been loaded or + * not. * - * @returns {Promise} True if the chunk was successfully loaded and false otherwise. + * @returns {Promise} Resolved when the chunk is loaded successfully, and + * rejected when there is an error. */ loadChunk = async (chunkIndex: number): Promise => { if (!this.isChunkLoaded(chunkIndex)) { @@ -205,14 +208,13 @@ class DocumentStore implements IDocumentStore { return true; }; /** - * @description Retrieves a file from the store based on its path, loading the necessary - * chunks and files if not already loaded. It returns the file or `null` if not found. + * @description Retrieves a file from the store based on its path, checking if it is + * already loaded and returning it if found, or loading it if necessary. * - * @param {string} path - Used to represent the file path that the function will check - * for existence and load if necessary. + * @param {string} path - Used to represent the file path that needs to be retrieved. * * @returns {Promise} A promise that resolves to a StructuredFile - * object or null if the file cannot be found in the specified chunk. + * object or null if the file is not found in the specified chunk. */ getFile = async (path: string): Promise => { if (!this.status.summary) @@ -255,10 +257,11 @@ class DocumentStore implements IDocumentStore { this.lookup.findIndex((sub) => sub.includes(this.getFileHash(path))) > -1; /** - * @description Adds a new document path to the end of an existing lookup subtable - * or creates a new table if the last one is full, preserving the chunk size. + * @description Updates the lookup subtable based on the provided path. If the last + * subtable is full, create a new one; otherwise, append the path to the existing subtable. * - * @param {string} path - Used to add a new element to the end of the lookup subtable. + * @param {string} path - Intended to represent a path to add to the end of the lookup + * table. */ addToEndOfLookup = (path: string) => { // If the last lookup subtable is full, create a new one @@ -272,10 +275,12 @@ class DocumentStore implements IDocumentStore { } }; /** - * @description Manages the chunking of files based on file size, creating new chunks - * if the last one is full or appending to it otherwise. + * @description Adds a new file to the end of an array of chunks if the last one is + * full or if the current chunk is not full, and pushes it to the appropriate position + * in the chunk array. * - * @param {StructuredFile} file - Used to add new files to an array of chunks for processing. + * @param {StructuredFile} file - Passed to add a file to an array of files, called + * chunks, within a larger data structure. */ addToEndOfChunks = (file: StructuredFile) => { // If the last lookup subtable is full, create a new one @@ -289,14 +294,16 @@ class DocumentStore implements IDocumentStore { } }; /** - * @description Allows adding a file to the collection of documents, checking for - * file existence and properly updating the content array if successful. + * @description Adds a file to the collection of stored files. It first checks if the + * `status.chunks` property is set and if the input file exists at its path. If so, + * it updates the file in the collection and returns `true`. Otherwise, it appends + * the file to the end of the lookup table and chunks list and returns `true`. * - * @param {StructuredFile} file - Used to represent a file that needs to be added to - * the content manager's chunks or lookups. + * @param {StructuredFile} file - Used to represent a file that is being added to the + * content library. * - * @returns {boolean} True if the file was successfully added to the content array - * and false otherwise. + * @returns {boolean} `true` if the file was successfully added to the content, and + * `false` otherwise. */ addFile = (file: StructuredFile): boolean => { if (!this.status.chunks) throw Error("Must call .load before adding files"); @@ -319,15 +326,13 @@ class DocumentStore implements IDocumentStore { return true; }; /** - * @description Updates a file in the store by checking its existence, loading it if - * necessary, and storing it in the correct chunk and index position. + * @description Updates a file in the store by checking if it exists, loading it if + * necessary, and storing it in the appropriate chunk and index position. * - * @param {StructuredFile} file - Used to represent a file within the application's - * data structure. Its purpose is to provide a reference to the file that needs to - * be updated. + * @param {StructuredFile} file - Used to represent a file that needs to be updated + * or added to the content library. * - * @returns {Promise} Ether true or false depending on whether the file was - * successfully updated or not. + * @returns {Promise} Whether the file was updated successfully or not. */ updateFile = async (file: StructuredFile): Promise => { if (!this.status.chunks) @@ -357,11 +362,10 @@ class DocumentStore implements IDocumentStore { return true; }; /** - * @description Returns an object containing the `meta` and `lookup` properties, which - * are likely used to store and retrieve metadata and data for documents managed by - * the class. + * @description Returns an object containing `meta` and `lookup` properties, which + * are presumably used to summarize or represent the contents of the document store. * - * @returns {Summary} An object containing two properties: `meta` and `lookup`. + * @returns {Summary} An object consisting of two properties: `meta` and `lookup`. */ outputSummary(): Summary { return { @@ -370,10 +374,12 @@ class DocumentStore implements IDocumentStore { }; } /** - * @description Generates and returns an object containing chunks of the original - * document,keyed by their chunk paths. + * @description Generates an object with chunk-related metadata and content for each + * chunk in the document. The method iterates through the document's content, slices + * it into chunks, and assigns a unique identifier to each chunk. * - * @returns {Record} An object containing chunk data. + * @returns {Record} An object where each key is a chunk path and the + * corresponding value is the contents of that chunk. */ outputChunks(): Record { const outputs: Record = {};