From 67914eb059a603cdd3aebf0f287c67965ef1f61e Mon Sep 17 00:00:00 2001 From: Ant Stanley Date: Wed, 18 Oct 2023 10:47:51 +0200 Subject: [PATCH] feat: dual module export (#607) --- jest.config.js => jest.config.cjs | 13 +++++-- package.json | 34 +++++++++++++++---- src/__tests__/checkAttribute.unit.test.ts | 6 ++-- src/__tests__/entity-creation.unit.test.ts | 6 ++-- src/__tests__/entity-properties.unit.test.ts | 4 +-- src/__tests__/entity.delete.unit.test.ts | 4 +-- src/__tests__/entity.get.int.test.ts | 4 +-- src/__tests__/entity.get.unit.test.ts | 4 +-- src/__tests__/entity.parse.unit.test.ts | 6 ++-- src/__tests__/entity.put.unit.test.ts | 4 +-- src/__tests__/entity.putBatch.unit.test.ts | 4 +-- src/__tests__/entity.transaction.unit.test.ts | 4 +-- src/__tests__/entity.update.unit.test.ts | 6 ++-- src/__tests__/entity.utils.unit.test.ts | 2 +- src/__tests__/expressionBuilder.unit.test.ts | 6 ++-- src/__tests__/format.unit.test.ts | 6 ++-- src/__tests__/formatItem.unit.test.ts | 8 ++--- src/__tests__/misc-tests.unit.test.ts | 6 ++-- src/__tests__/normalizeData.unit.test.ts | 8 ++--- src/__tests__/parse-alias.unit.test.ts | 6 ++-- src/__tests__/parse.unit.test.ts | 6 ++-- src/__tests__/parseCompositeKey.unit.test.ts | 4 +-- src/__tests__/parseEntity.unit.test.ts | 2 +- src/__tests__/parseMapping.unit.test.ts | 4 +-- src/__tests__/parseTable.unit.test.ts | 4 +-- .../parseTableAttributes.unit.test.ts | 4 +-- src/__tests__/projectionBuilder.unit.test.ts | 6 ++-- src/__tests__/table-creation.unit.test.ts | 4 +-- src/__tests__/table.batchGet.unit.test.ts | 4 +-- src/__tests__/table.batchWrite.unit.test.ts | 4 +-- src/__tests__/table.entities.unit.test.ts | 4 +-- .../table.entity-actions.unit.test.ts | 4 +-- src/__tests__/table.query.unit.test.ts | 4 +-- src/__tests__/table.scan.unit.test.ts | 4 +-- src/__tests__/table.transactGet.unit.test.ts | 4 +-- .../table.transactWrite.unit.test.ts | 4 +-- src/__tests__/type-infering.unit.test.ts | 6 ++-- src/__tests__/utils.unit.test.ts | 2 +- src/__tests__/validateTypes.unit.test.ts | 4 +-- src/classes/Entity/Entity.ts | 27 ++++++++------- src/classes/Entity/deep-copy.d.ts | 4 +++ src/classes/Entity/index.ts | 6 ++-- src/classes/Entity/types.ts | 6 ++-- src/classes/Table/Table.ts | 17 +++++----- src/classes/Table/index.ts | 6 ++-- src/classes/Table/types.ts | 8 ++--- src/index.ts | 6 ++-- src/lib/checkAttribute.ts | 2 +- src/lib/expressionBuilder.ts | 6 ++-- src/lib/formatItem.ts | 6 ++-- src/lib/getKey.ts | 4 +-- src/lib/normalizeData.ts | 4 +-- src/lib/parseCompositeKey.ts | 8 ++--- src/lib/parseEntity.ts | 8 ++--- src/lib/parseEntityAttributes.ts | 10 +++--- src/lib/parseMapping.ts | 6 ++-- src/lib/parseTable.ts | 6 ++-- src/lib/parseTableAttributes.ts | 4 +-- src/lib/projectionBuilder.ts | 6 ++-- src/lib/utils.ts | 4 +-- src/lib/validateTypes.ts | 2 +- test-d/index.cjs.test-d.ts | 1 + test-d/index.esm.test-d.ts | 1 + test-d/index.test-d.ts | 1 - tsconfig.build.json | 4 --- tsconfig.cjs.json | 9 +++++ tsconfig.esm.json | 10 ++++++ tsconfig.json | 5 ++- 68 files changed, 228 insertions(+), 178 deletions(-) rename jest.config.js => jest.config.cjs (56%) create mode 100644 src/classes/Entity/deep-copy.d.ts create mode 100644 test-d/index.cjs.test-d.ts create mode 100644 test-d/index.esm.test-d.ts delete mode 100644 test-d/index.test-d.ts delete mode 100644 tsconfig.build.json create mode 100644 tsconfig.cjs.json create mode 100644 tsconfig.esm.json diff --git a/jest.config.js b/jest.config.cjs similarity index 56% rename from jest.config.js rename to jest.config.cjs index 60488ca96..dfb1558b1 100644 --- a/jest.config.js +++ b/jest.config.cjs @@ -3,7 +3,16 @@ module.exports = { testMatch: ['**/?(*.)+(unit.test).+(ts|tsx|js)'], testPathIgnorePatterns: ['/__tests__/entities/*', '/__tests__/tables/*'], coveragePathIgnorePatterns: ['/__tests__/*'], + extensionsToTreatAsEsm: ['.ts'], + moduleNameMapper: { + '^(\\.{1,2}/.*)\\.js$': '$1', + }, transform: { - '^.+\\.(ts|tsx)$': 'ts-jest' - } + '^.+\\.[tj]sx?$': [ + 'ts-jest', + { + useESM: true, + }, + ], + }, } diff --git a/package.json b/package.json index 7bce2e3a9..a3dbddce0 100644 --- a/package.json +++ b/package.json @@ -2,8 +2,21 @@ "name": "dynamodb-toolbox", "description": "A simple set of tools for working with Amazon DynamoDB and the DocumentClient.", "author": "Jeremy Daly ", - "main": "dist/index.js", - "types": "dist/index.d.ts", + "main": "dist/cjs/index.js", + "types": "dist/cjs/index.d.ts", + "exports": { + ".": { + "import": { + "default": "./dist/esm/index.js", + "types": "./dist/esm/index.d.ts" + }, + "require": { + "default": "./dist/cjs/index.js", + "types": "./dist/cjs/index.d.ts" + } + } + }, + "type": "module", "scripts": { "test": "jest unit", "test-cov": "jest unit --coverage", @@ -11,7 +24,10 @@ "test-types": "tsd", "check-types": "tsc --noEmit", "lint": "eslint .", - "build": "rm -rf dist && tsc -p tsconfig.build.json", + "build:cjs": "tsc -p tsconfig.cjs.json && echo '{ \"type\": \"commonjs\" }' > dist/cjs/package.json", + "build:esm": "tsc -p tsconfig.esm.json && echo '{ \"type\": \"module\" }' > dist/esm/package.json", + "build": "npm run build:cjs & npm run build:esm", + "prebuild": "rm -rf dist", "prepublishOnly": "npm test && npm run lint && npm run test-types", "changelog": "git log $(git describe --tags --abbrev=0)..HEAD --oneline" }, @@ -62,9 +78,13 @@ "typescript": "^4.1.3" }, "files": [ - "dist/index.*", - "dist/constants.*", - "dist/classes/", - "dist/lib/" + "dist/cjs/index.*", + "dist/cjs/constants.*", + "dist/cjs/classes/", + "dist/cjs/lib/", + "dist/esm/index.*", + "dist/esm/constants.*", + "dist/esm/classes/", + "dist/esm/lib/" ] } diff --git a/src/__tests__/checkAttribute.unit.test.ts b/src/__tests__/checkAttribute.unit.test.ts index 72394a956..3ba564e7e 100644 --- a/src/__tests__/checkAttribute.unit.test.ts +++ b/src/__tests__/checkAttribute.unit.test.ts @@ -1,8 +1,8 @@ -import checkAttribute from '../lib/checkAttribute' +import checkAttribute from '../lib/checkAttribute.js' // Require Table and Entity classes -import Table from '../classes/Table' -import Entity from '../classes/Entity' +import Table from '../classes/Table/Table.js' +import Entity from '../classes/Entity/Entity.js' // Create basic table const DefaultTable = new Table({ diff --git a/src/__tests__/entity-creation.unit.test.ts b/src/__tests__/entity-creation.unit.test.ts index e5939e521..d2f9dc9c7 100644 --- a/src/__tests__/entity-creation.unit.test.ts +++ b/src/__tests__/entity-creation.unit.test.ts @@ -1,6 +1,6 @@ -import Table from '../classes/Table' -import Entity from '../classes/Entity' -import { DocumentClient, DocumentClientWithWrappedNumbers } from './bootstrap.test' +import Table from '../classes/Table/Table.js' +import Entity from '../classes/Entity/Entity.js' +import { DocumentClient, DocumentClientWithWrappedNumbers } from './bootstrap.test.js' const tableAddEntity = jest.spyOn(Table.prototype, 'addEntity').mockReturnValue() diff --git a/src/__tests__/entity-properties.unit.test.ts b/src/__tests__/entity-properties.unit.test.ts index a40413eee..3a5e367b0 100644 --- a/src/__tests__/entity-properties.unit.test.ts +++ b/src/__tests__/entity-properties.unit.test.ts @@ -1,5 +1,5 @@ -import Table from '../classes/Table' -import Entity from '../classes/Entity' +import Table from '../classes/Table/Table.js' +import Entity from '../classes/Entity/Entity.js' describe('Entity properties', () => { describe('table', () => { diff --git a/src/__tests__/entity.delete.unit.test.ts b/src/__tests__/entity.delete.unit.test.ts index 42d6d3716..6dfa2ba81 100644 --- a/src/__tests__/entity.delete.unit.test.ts +++ b/src/__tests__/entity.delete.unit.test.ts @@ -1,5 +1,5 @@ -import { Entity, Table } from '..' -import { DocumentClient } from './bootstrap.test' +import { Entity, Table } from '../index.js' +import { DocumentClient } from './bootstrap.test.js' const TestTable = new Table({ name: 'test-table', diff --git a/src/__tests__/entity.get.int.test.ts b/src/__tests__/entity.get.int.test.ts index 01572ef89..935574620 100644 --- a/src/__tests__/entity.get.int.test.ts +++ b/src/__tests__/entity.get.int.test.ts @@ -1,6 +1,6 @@ // @ts-nocheck -import { Table, Entity } from '../index' -import { DocumentClient } from './bootstrap.test' +import { Table, Entity } from '../index.js' +import { DocumentClient } from './bootstrap.test.js' const TestTable = new Table({ name: 'test-table', diff --git a/src/__tests__/entity.get.unit.test.ts b/src/__tests__/entity.get.unit.test.ts index 44c23c800..499069210 100644 --- a/src/__tests__/entity.get.unit.test.ts +++ b/src/__tests__/entity.get.unit.test.ts @@ -1,5 +1,5 @@ -import { Table, Entity } from '..' -import { DocumentClient } from './bootstrap.test' +import { Table, Entity } from '../index.js' +import { DocumentClient } from './bootstrap.test.js' const TestTable = new Table({ name: 'test-table', diff --git a/src/__tests__/entity.parse.unit.test.ts b/src/__tests__/entity.parse.unit.test.ts index e4aae71fb..a8a9af808 100644 --- a/src/__tests__/entity.parse.unit.test.ts +++ b/src/__tests__/entity.parse.unit.test.ts @@ -1,7 +1,7 @@ -import { DocumentClientWithWrappedNumbers } from './bootstrap.test' +import { DocumentClientWithWrappedNumbers } from './bootstrap.test.js' -import Table from '../classes/Table' -import Entity from '../classes/Entity' +import Table from '../classes/Table/Table.js' +import Entity from '../classes/Entity/Entity.js' import { unmarshall } from '@aws-sdk/util-dynamodb' const TestTable = new Table({ diff --git a/src/__tests__/entity.put.unit.test.ts b/src/__tests__/entity.put.unit.test.ts index 882d6621d..2c96755ca 100644 --- a/src/__tests__/entity.put.unit.test.ts +++ b/src/__tests__/entity.put.unit.test.ts @@ -1,5 +1,5 @@ -import { Table, Entity } from '../index' -import { DocumentClient } from './bootstrap.test' +import { Table, Entity } from '../index.js' +import { DocumentClient } from './bootstrap.test.js' import assert from 'assert' const TestTable = new Table({ diff --git a/src/__tests__/entity.putBatch.unit.test.ts b/src/__tests__/entity.putBatch.unit.test.ts index c665d7fe3..2815747b4 100644 --- a/src/__tests__/entity.putBatch.unit.test.ts +++ b/src/__tests__/entity.putBatch.unit.test.ts @@ -1,5 +1,5 @@ -import { Table, Entity } from '../index' -import { DocumentClient } from './bootstrap.test' +import { Table, Entity } from '../index.js' +import { DocumentClient } from './bootstrap.test.js' const TestTable = new Table({ name: 'test-table', diff --git a/src/__tests__/entity.transaction.unit.test.ts b/src/__tests__/entity.transaction.unit.test.ts index 438667956..c2c7c5e56 100644 --- a/src/__tests__/entity.transaction.unit.test.ts +++ b/src/__tests__/entity.transaction.unit.test.ts @@ -1,5 +1,5 @@ -import { Table, Entity } from '../index' -import { DocumentClient } from './bootstrap.test' +import { Table, Entity } from '../index.js' +import { DocumentClient } from './bootstrap.test.js' import assert from 'assert' const TestTable = new Table({ diff --git a/src/__tests__/entity.update.unit.test.ts b/src/__tests__/entity.update.unit.test.ts index d170c22e3..0c0cc9d0d 100644 --- a/src/__tests__/entity.update.unit.test.ts +++ b/src/__tests__/entity.update.unit.test.ts @@ -1,9 +1,9 @@ import { ATTRIBUTE_VALUES_LIST_DEFAULT_KEY, ATTRIBUTE_VALUES_LIST_DEFAULT_VALUE -} from '../constants' -import { Table, Entity } from '../index' -import { DocumentClient } from './bootstrap.test' +} from '../constants.js' +import { Table, Entity } from '../index.js' +import { DocumentClient } from './bootstrap.test.js' import assert from 'assert' const TestTable = new Table({ diff --git a/src/__tests__/entity.utils.unit.test.ts b/src/__tests__/entity.utils.unit.test.ts index f96d397c9..7b514e5c0 100644 --- a/src/__tests__/entity.utils.unit.test.ts +++ b/src/__tests__/entity.utils.unit.test.ts @@ -1,4 +1,4 @@ -import { shouldExecute, shouldParse } from '../classes/Entity' +import { shouldExecute, shouldParse } from '../classes/Entity/Entity.js' describe('Entity - utils', () => { it('should execute', () => { diff --git a/src/__tests__/expressionBuilder.unit.test.ts b/src/__tests__/expressionBuilder.unit.test.ts index 48ca57acf..f83c799fd 100644 --- a/src/__tests__/expressionBuilder.unit.test.ts +++ b/src/__tests__/expressionBuilder.unit.test.ts @@ -1,9 +1,9 @@ -import Table from '../classes/Table' -import Entity from '../classes/Entity' +import Table from '../classes/Table/Table.js' +import Entity from '../classes/Entity/Entity.js' import { default as expressionBuilder, SUPPORTED_FILTER_EXP_ATTR_REF_OPERATORS -} from '../lib/expressionBuilder' +} from '../lib/expressionBuilder.js' const TestTable = new Table({ name: 'test-table', diff --git a/src/__tests__/format.unit.test.ts b/src/__tests__/format.unit.test.ts index 9883a90e8..4d7a03730 100644 --- a/src/__tests__/format.unit.test.ts +++ b/src/__tests__/format.unit.test.ts @@ -1,6 +1,6 @@ -import Table from '../classes/Table' -import Entity from '../classes/Entity' -import { DocumentClient } from './bootstrap.test' +import Table from '../classes/Table/Table.js' +import Entity from '../classes/Entity/Entity.js' +import { DocumentClient } from './bootstrap.test.js' const TestTable = new Table({ name: 'test-table', diff --git a/src/__tests__/formatItem.unit.test.ts b/src/__tests__/formatItem.unit.test.ts index c7fc75e3d..ef79d792f 100644 --- a/src/__tests__/formatItem.unit.test.ts +++ b/src/__tests__/formatItem.unit.test.ts @@ -1,9 +1,9 @@ -import formatItem from '../lib/formatItem' +import formatItem from '../lib/formatItem.js' -import { DocumentClient } from './bootstrap.test' +import { DocumentClient } from './bootstrap.test.js' -import Table from '../classes/Table' -import Entity from '../classes/Entity' +import Table from '../classes/Table/Table.js' +import Entity from '../classes/Entity/Entity.js' // Create basic table const DefaultTable = new Table({ diff --git a/src/__tests__/misc-tests.unit.test.ts b/src/__tests__/misc-tests.unit.test.ts index b6426a7bf..6e0c32643 100644 --- a/src/__tests__/misc-tests.unit.test.ts +++ b/src/__tests__/misc-tests.unit.test.ts @@ -1,6 +1,6 @@ -import Table from '../classes/Table' -import Entity from '../classes/Entity' -import { DocumentClient } from './bootstrap.test' +import Table from '../classes/Table/Table.js' +import Entity from '../classes/Entity/Entity.js' +import { DocumentClient } from './bootstrap.test.js' describe('Misc Tests (development only)', () => { it('uses a numeric pk value', async () => { diff --git a/src/__tests__/normalizeData.unit.test.ts b/src/__tests__/normalizeData.unit.test.ts index 252b93ef4..f957b56e1 100644 --- a/src/__tests__/normalizeData.unit.test.ts +++ b/src/__tests__/normalizeData.unit.test.ts @@ -1,9 +1,9 @@ -import normalizeData from '../lib/normalizeData' +import normalizeData from '../lib/normalizeData.js' -import { DocumentClient } from './bootstrap.test' +import { DocumentClient } from './bootstrap.test.js' -import Table from '../classes/Table' -import Entity from '../classes/Entity' +import Table from '../classes/Table/Table.js' +import Entity from '../classes/Entity/Entity.js' const DefaultTable = new Table({ name: 'test-table', diff --git a/src/__tests__/parse-alias.unit.test.ts b/src/__tests__/parse-alias.unit.test.ts index 2aaf7266c..2eb03d39f 100644 --- a/src/__tests__/parse-alias.unit.test.ts +++ b/src/__tests__/parse-alias.unit.test.ts @@ -1,6 +1,6 @@ -import Table from '../classes/Table' -import Entity from '../classes/Entity' -import { DocumentClient } from './bootstrap.test' +import Table from '../classes/Table/Table.js' +import Entity from '../classes/Entity/Entity.js' +import { DocumentClient } from './bootstrap.test.js' const TestTable = new Table({ name: 'test-alias', diff --git a/src/__tests__/parse.unit.test.ts b/src/__tests__/parse.unit.test.ts index 54204a770..518cd9bf2 100644 --- a/src/__tests__/parse.unit.test.ts +++ b/src/__tests__/parse.unit.test.ts @@ -1,6 +1,6 @@ -import Table from '../classes/Table' -import Entity from '../classes/Entity' -import { DocumentClient } from './bootstrap.test' +import Table from '../classes/Table/Table.js' +import Entity from '../classes/Entity/Entity.js' +import { DocumentClient } from './bootstrap.test.js' const TestTable = new Table({ name: 'test-table', diff --git a/src/__tests__/parseCompositeKey.unit.test.ts b/src/__tests__/parseCompositeKey.unit.test.ts index a2853525d..d1adcb9a7 100644 --- a/src/__tests__/parseCompositeKey.unit.test.ts +++ b/src/__tests__/parseCompositeKey.unit.test.ts @@ -1,5 +1,5 @@ -import { TrackingInfo } from '../lib/parseEntity' -import parseCompositeKey from '../lib/parseCompositeKey' +import { TrackingInfo } from '../lib/parseEntity.js' +import parseCompositeKey from '../lib/parseCompositeKey.js' // Simulate attributes const attributes = { diff --git a/src/__tests__/parseEntity.unit.test.ts b/src/__tests__/parseEntity.unit.test.ts index f1b45e0d2..e56a988de 100644 --- a/src/__tests__/parseEntity.unit.test.ts +++ b/src/__tests__/parseEntity.unit.test.ts @@ -1,4 +1,4 @@ -import parseEntity from '../lib/parseEntity' +import parseEntity from '../lib/parseEntity.js' // Simulate Entity config const entity = { diff --git a/src/__tests__/parseMapping.unit.test.ts b/src/__tests__/parseMapping.unit.test.ts index e23eecd91..890c3a663 100644 --- a/src/__tests__/parseMapping.unit.test.ts +++ b/src/__tests__/parseMapping.unit.test.ts @@ -1,5 +1,5 @@ -import parseMapping from '../lib/parseMapping' -import { TrackingInfo } from '../lib/parseEntity' +import parseMapping from '../lib/parseMapping.js' +import { TrackingInfo } from '../lib/parseEntity.js' let track: TrackingInfo = { fields: [], diff --git a/src/__tests__/parseTable.unit.test.ts b/src/__tests__/parseTable.unit.test.ts index 6fa3c29f8..7ae5463a9 100644 --- a/src/__tests__/parseTable.unit.test.ts +++ b/src/__tests__/parseTable.unit.test.ts @@ -1,7 +1,7 @@ -import parseTable from '../lib/parseTable' +import parseTable from '../lib/parseTable.js' // Require Table and Entity classes -import { TableConstructor } from '../classes/Table' +import { TableConstructor } from '../classes/Table/types.js' const table: TableConstructor<'test-table', 'pk', 'sk'> = { name: 'test-table', diff --git a/src/__tests__/parseTableAttributes.unit.test.ts b/src/__tests__/parseTableAttributes.unit.test.ts index 1c73929c1..17a0e6734 100644 --- a/src/__tests__/parseTableAttributes.unit.test.ts +++ b/src/__tests__/parseTableAttributes.unit.test.ts @@ -1,5 +1,5 @@ -import { TableAttributes } from '../classes/Table' -import parseTableAttributes from '../lib/parseTableAttributes' +import { TableAttributes } from '../classes/Table/types.js' +import parseTableAttributes from '../lib/parseTableAttributes.js' const attrs: TableAttributes = { pk: 'string', diff --git a/src/__tests__/projectionBuilder.unit.test.ts b/src/__tests__/projectionBuilder.unit.test.ts index 51338279a..d21113682 100644 --- a/src/__tests__/projectionBuilder.unit.test.ts +++ b/src/__tests__/projectionBuilder.unit.test.ts @@ -1,7 +1,7 @@ -import projectionBuilder from '../lib/projectionBuilder' +import projectionBuilder from '../lib/projectionBuilder.js' -import Table from '../classes/Table' -import Entity from '../classes/Entity' +import Table from '../classes/Table/Table.js' +import Entity from '../classes/Entity/Entity.js' const DefaultTable = new Table({ name: 'test-table', diff --git a/src/__tests__/table-creation.unit.test.ts b/src/__tests__/table-creation.unit.test.ts index f999b8058..868a82e42 100644 --- a/src/__tests__/table-creation.unit.test.ts +++ b/src/__tests__/table-creation.unit.test.ts @@ -1,5 +1,5 @@ -import Table from '../classes/Table' -import { DocumentClient, DocumentClientWithoutConfig } from './bootstrap.test' +import Table from '../classes/Table/Table.js' +import { DocumentClient, DocumentClientWithoutConfig } from './bootstrap.test.js' describe('Table creation', () => { it('creates table w/ minimum options', async () => { diff --git a/src/__tests__/table.batchGet.unit.test.ts b/src/__tests__/table.batchGet.unit.test.ts index 37fca0871..ab0279f8b 100644 --- a/src/__tests__/table.batchGet.unit.test.ts +++ b/src/__tests__/table.batchGet.unit.test.ts @@ -1,5 +1,5 @@ -import { Table, Entity } from '../index' -import { DocumentClient } from './bootstrap.test' +import { Table, Entity } from '../index.js' +import { DocumentClient } from './bootstrap.test.js' const TestTable = new Table({ name: 'test-table', diff --git a/src/__tests__/table.batchWrite.unit.test.ts b/src/__tests__/table.batchWrite.unit.test.ts index a76df783b..250a300d7 100644 --- a/src/__tests__/table.batchWrite.unit.test.ts +++ b/src/__tests__/table.batchWrite.unit.test.ts @@ -1,6 +1,6 @@ import { BatchWriteCommandInput } from '@aws-sdk/lib-dynamodb' -import { Entity, Table } from '../index' -import { DocumentClient as docClient } from './bootstrap.test' +import { Entity, Table } from '../index.js' +import { DocumentClient as docClient } from './bootstrap.test.js' import assert from 'assert' const TestTable = new Table({ diff --git a/src/__tests__/table.entities.unit.test.ts b/src/__tests__/table.entities.unit.test.ts index feff685a7..7ff8e1ed2 100644 --- a/src/__tests__/table.entities.unit.test.ts +++ b/src/__tests__/table.entities.unit.test.ts @@ -1,5 +1,5 @@ -import { Table, Entity } from '../index' -import { DocumentClient } from './bootstrap.test' +import { Table, Entity } from '../index.js' +import { DocumentClient } from './bootstrap.test.js' let TestTable: any let TestEntity: any diff --git a/src/__tests__/table.entity-actions.unit.test.ts b/src/__tests__/table.entity-actions.unit.test.ts index 27eb70bfa..c92fddd4c 100644 --- a/src/__tests__/table.entity-actions.unit.test.ts +++ b/src/__tests__/table.entity-actions.unit.test.ts @@ -1,5 +1,5 @@ -import { Table, Entity } from '../index' -import { DocumentClient } from './bootstrap.test' +import { Table, Entity } from '../index.js' +import { DocumentClient } from './bootstrap.test.js' const TestTable = new Table({ name: 'test-table', diff --git a/src/__tests__/table.query.unit.test.ts b/src/__tests__/table.query.unit.test.ts index c9a2703dd..e88659d38 100644 --- a/src/__tests__/table.query.unit.test.ts +++ b/src/__tests__/table.query.unit.test.ts @@ -1,5 +1,5 @@ -import { Entity, Table } from '../index' -import { DocumentClient } from './bootstrap.test' +import { Entity, Table } from '../index.js' +import { DocumentClient } from './bootstrap.test.js' const TestTable = new Table({ name: 'test-table', diff --git a/src/__tests__/table.scan.unit.test.ts b/src/__tests__/table.scan.unit.test.ts index f41a0ecb5..24650e605 100644 --- a/src/__tests__/table.scan.unit.test.ts +++ b/src/__tests__/table.scan.unit.test.ts @@ -1,5 +1,5 @@ -import { Entity, Table } from '../index' -import { DocumentClient } from './bootstrap.test' +import { Entity, Table } from '../index.js' +import { DocumentClient } from './bootstrap.test.js' const TestTable = new Table({ name: 'test-table', diff --git a/src/__tests__/table.transactGet.unit.test.ts b/src/__tests__/table.transactGet.unit.test.ts index edf459a2d..2194fba8b 100644 --- a/src/__tests__/table.transactGet.unit.test.ts +++ b/src/__tests__/table.transactGet.unit.test.ts @@ -1,5 +1,5 @@ -import { Table, Entity } from '../index' -import { DocumentClient } from './bootstrap.test' +import { Table, Entity } from '../index.js' +import { DocumentClient } from './bootstrap.test.js' const TestTable = new Table({ name: 'test-table', diff --git a/src/__tests__/table.transactWrite.unit.test.ts b/src/__tests__/table.transactWrite.unit.test.ts index e148a247b..18d5b20e1 100644 --- a/src/__tests__/table.transactWrite.unit.test.ts +++ b/src/__tests__/table.transactWrite.unit.test.ts @@ -1,5 +1,5 @@ -import { Table, Entity } from '../index' -import { DocumentClient as docClient } from './bootstrap.test' +import { Table, Entity } from '../index.js' +import { DocumentClient as docClient } from './bootstrap.test.js' import assert from 'assert' const TestTable = new Table({ diff --git a/src/__tests__/type-infering.unit.test.ts b/src/__tests__/type-infering.unit.test.ts index 57d405703..8b2d10921 100644 --- a/src/__tests__/type-infering.unit.test.ts +++ b/src/__tests__/type-infering.unit.test.ts @@ -8,9 +8,9 @@ import { DeleteOptions, UpdateOptions, ConditionsOrFilters, AttributeMap, -} from 'classes/Entity' +} from 'classes/Entity/types.js' -import { Table, Entity } from '../index' +import { Table, Entity } from '../index.js' import { ReturnConsumedCapacity, ReturnItemCollectionMetrics, Select } from '@aws-sdk/client-dynamodb' import { DeleteCommandInput, @@ -20,7 +20,7 @@ import { PutCommandInput, PutCommandOutput, QueryCommandInput, ScanCommandInput, UpdateCommandInput, UpdateCommandOutput, } from '@aws-sdk/lib-dynamodb' -import { DocumentClient } from './bootstrap.test' +import { DocumentClient } from './bootstrap.test.js' const omit = , K extends (keyof O)[]>( obj: O, diff --git a/src/__tests__/utils.unit.test.ts b/src/__tests__/utils.unit.test.ts index 39f991ddc..5bf823d46 100644 --- a/src/__tests__/utils.unit.test.ts +++ b/src/__tests__/utils.unit.test.ts @@ -1,4 +1,4 @@ -import { toBool, hasValue, error } from '../lib/utils' +import { toBool, hasValue, error } from '../lib/utils.js' describe('utility functions', () => { test('toBool', () => { diff --git a/src/__tests__/validateTypes.unit.test.ts b/src/__tests__/validateTypes.unit.test.ts index 418225c1e..2bed760df 100644 --- a/src/__tests__/validateTypes.unit.test.ts +++ b/src/__tests__/validateTypes.unit.test.ts @@ -1,5 +1,5 @@ -import { toDynamoBigInt } from '../lib/utils' -import validateTypes from '../lib/validateTypes' +import { toDynamoBigInt } from '../lib/utils.js' +import validateTypes from '../lib/validateTypes.js' describe('validateTypes', () => { it('validates string', async () => { diff --git a/src/classes/Entity/Entity.ts b/src/classes/Entity/Entity.ts index a083a6141..ef7c7d002 100644 --- a/src/classes/Entity/Entity.ts +++ b/src/classes/Entity/Entity.ts @@ -19,22 +19,23 @@ import type { ScanInput, TransactGetItem } from '@aws-sdk/client-dynamodb' -import cloneDeep from 'deep-copy' +import * as cloneDeep from 'deep-copy' + import type { A, B, O } from 'ts-toolbelt' -import parseEntity from '../../lib/parseEntity' -import validateTypes from '../../lib/validateTypes' -import normalizeData from '../../lib/normalizeData' -import formatItem from '../../lib/formatItem' -import getKey from '../../lib/getKey' -import parseConditions from '../../lib/expressionBuilder' -import parseProjections from '../../lib/projectionBuilder' -import { error, transformAttr, isEmpty, If, FirstDefined, Compute } from '../../lib/utils' +import parseEntity from '../../lib/parseEntity.js' +import validateTypes from '../../lib/validateTypes.js' +import normalizeData from '../../lib/normalizeData.js' +import formatItem from '../../lib/formatItem.js' +import getKey from '../../lib/getKey.js' +import parseConditions from '../../lib/expressionBuilder.js' +import parseProjections from '../../lib/projectionBuilder.js' +import { error, transformAttr, isEmpty, If, FirstDefined, Compute } from '../../lib/utils.js' import { ATTRIBUTE_VALUES_LIST_DEFAULT_KEY, ATTRIBUTE_VALUES_LIST_DEFAULT_VALUE, -} from '../../constants' -import type { ScanOptions, TableDef } from '../Table' +} from '../../constants.js' +import type { ScanOptions, TableDef } from '../Table/types.js' import type { $GetOptions, $PutOptions, @@ -61,7 +62,7 @@ import type { Writable, Readonly, $PutBatchOptions, AttributeMap, -} from './types' +} from './types.js' class Entity(arg: T): T + export default dcopy +} diff --git a/src/classes/Entity/index.ts b/src/classes/Entity/index.ts index ea370d22c..134001a2f 100644 --- a/src/classes/Entity/index.ts +++ b/src/classes/Entity/index.ts @@ -1,3 +1,3 @@ -export { default as default } from './Entity' -export * from './Entity' -export * from './types' +export { default as default } from './Entity.js' +export * from './Entity.js' +export * from './types.js' diff --git a/src/classes/Entity/types.ts b/src/classes/Entity/types.ts index 5caf9d563..feffcdba1 100644 --- a/src/classes/Entity/types.ts +++ b/src/classes/Entity/types.ts @@ -2,9 +2,9 @@ import type { A, B, O, F } from 'ts-toolbelt' import { NativeAttributeValue } from '@aws-sdk/util-dynamodb' import { ReturnConsumedCapacity, ReturnItemCollectionMetrics } from '@aws-sdk/client-dynamodb' -import type { Compute, FirstDefined, If } from '../../lib/utils' -import type { DynamoDBKeyTypes, DynamoDBTypes, $QueryOptions, TableDef } from '../Table' -import Entity from './Entity' +import type { Compute, FirstDefined, If } from '../../lib/utils.js' +import type { DynamoDBKeyTypes, DynamoDBTypes, $QueryOptions, TableDef } from '../Table/types.js' +import Entity from './Entity.js' import { UpdateCommandInput } from '@aws-sdk/lib-dynamodb' export interface EntityConstructor< diff --git a/src/classes/Table/Table.ts b/src/classes/Table/Table.ts index 37218e66b..3734f20ea 100644 --- a/src/classes/Table/Table.ts +++ b/src/classes/Table/Table.ts @@ -1,15 +1,16 @@ import type { A, O } from 'ts-toolbelt' -import { parseTable, ParsedTable } from '../../lib/parseTable' -import parseFilters from '../../lib/expressionBuilder' -import validateTypes from '../../lib/validateTypes' -import Entity, { AttributeMap } from '../Entity' +import { parseTable, ParsedTable } from '../../lib/parseTable.js' +import parseFilters from '../../lib/expressionBuilder.js' +import validateTypes from '../../lib/validateTypes.js' +import Entity from '../Entity/Entity.js' +import { AttributeMap } from '../Entity/types.js' import { default as parseProjections, ProjectionAttributes, ProjectionAttributesTable, -} from '../../lib/projectionBuilder' -import type { ParsedEntity } from '../../lib/parseEntity' +} from '../../lib/projectionBuilder.js' +import type { ParsedEntity } from '../../lib/parseEntity.js' import type { BatchGetOptions, BatchGetParamsMeta, @@ -23,9 +24,9 @@ import type { transactGetParamsOptions, TransactWriteOptions, transactWriteParamsOptions, -} from './types' +} from './types.js' -import { error, conditionError, If, Compute } from '../../lib/utils' +import { error, conditionError, If, Compute } from '../../lib/utils.js' import { BatchGetCommand, BatchGetCommandInput, BatchWriteCommand, diff --git a/src/classes/Table/index.ts b/src/classes/Table/index.ts index 788c753c7..3170ea6a6 100644 --- a/src/classes/Table/index.ts +++ b/src/classes/Table/index.ts @@ -1,3 +1,3 @@ -export { default as default } from './Table' -export * from './Table' -export * from './types' +export { default as default } from './Table.js' +export * from './Table.js' +export * from './types.js' diff --git a/src/classes/Table/types.ts b/src/classes/Table/types.ts index 3a73b97a4..bfbf60a3e 100644 --- a/src/classes/Table/types.ts +++ b/src/classes/Table/types.ts @@ -2,10 +2,10 @@ import { ReturnConsumedCapacity, ReturnItemCollectionMetrics, Select } from '@aw import { DynamoDBDocumentClient, ScanCommandInput, TransactGetCommandInput } from '@aws-sdk/lib-dynamodb' import type { A, O } from 'ts-toolbelt' -import type { ProjectionAttributes } from '../../lib/projectionBuilder' -import type { FilterExpressions } from '../../lib/expressionBuilder' -import type { $ReadOptions, ConditionsOrFilters } from '../Entity' -import type Table from './Table' +import type { ProjectionAttributes } from '../../lib/projectionBuilder.js' +import type { FilterExpressions } from '../../lib/expressionBuilder.js' +import type { $ReadOptions, ConditionsOrFilters } from '../Entity/types.js' +import type Table from './Table.js' export interface TableConstructor< Name extends string, diff --git a/src/index.ts b/src/index.ts index 7373da0b3..b81481f91 100644 --- a/src/index.ts +++ b/src/index.ts @@ -1,5 +1,5 @@ -import Table from './classes/Table' -import Entity from './classes/Entity' +import Table from './classes/Table/Table.js' +import Entity from './classes/Entity/Entity.js' import type { GetOptions, QueryOptions, @@ -8,7 +8,7 @@ import type { UpdateOptions, EntityItem, InferEntityItem -} from './classes/Entity' +} from './classes/Entity/types.js' export { Table, diff --git a/src/lib/checkAttribute.ts b/src/lib/checkAttribute.ts index 874d194de..105fd70dc 100644 --- a/src/lib/checkAttribute.ts +++ b/src/lib/checkAttribute.ts @@ -4,7 +4,7 @@ * @license MIT */ -import { error } from './utils' +import { error } from './utils.js' // Check attribute against attribute set export default (attr: string, attrs: any): string => { diff --git a/src/lib/expressionBuilder.ts b/src/lib/expressionBuilder.ts index c0e3fdaff..9613ed9d9 100644 --- a/src/lib/expressionBuilder.ts +++ b/src/lib/expressionBuilder.ts @@ -9,9 +9,9 @@ import { A } from 'ts-toolbelt' -import checkAttribute from './checkAttribute' -import { error, toDynamoBigInt } from './utils' -import { TableDef } from '../classes/Table' +import checkAttribute from './checkAttribute.js' +import { error, toDynamoBigInt } from './utils.js' +import { TableDef } from '../classes/Table/types.js' interface AttrRef { attr: string diff --git a/src/lib/formatItem.ts b/src/lib/formatItem.ts index c557be563..ae77678e0 100644 --- a/src/lib/formatItem.ts +++ b/src/lib/formatItem.ts @@ -5,9 +5,9 @@ */ import type { NativeAttributeValue, NativeScalarAttributeValue, NumberValue } from '@aws-sdk/util-dynamodb' -import type { PureAttributeDefinition } from '../classes/Entity' -import validateTypes from './validateTypes' -import type { Linked } from './parseEntity' +import type { PureAttributeDefinition } from '../classes/Entity/types.js' +import validateTypes from './validateTypes.js' +import type { Linked } from './parseEntity.js' // Convert from DocumentClient values, which may be wrapped sets or numbers, // into normal TS values. diff --git a/src/lib/getKey.ts b/src/lib/getKey.ts index bbe44f41e..c505baaa4 100644 --- a/src/lib/getKey.ts +++ b/src/lib/getKey.ts @@ -4,8 +4,8 @@ * @license MIT */ -import validateTypes from './validateTypes' -import { error, transformAttr } from './utils' +import validateTypes from './validateTypes.js' +import { error, transformAttr } from './utils.js' // Get partitionKey/sortKey export default () => ( diff --git a/src/lib/normalizeData.ts b/src/lib/normalizeData.ts index 23f977f23..243881e74 100644 --- a/src/lib/normalizeData.ts +++ b/src/lib/normalizeData.ts @@ -7,8 +7,8 @@ import { DynamoDBDocumentClient } from '@aws-sdk/lib-dynamodb' -import validateTypes from './validateTypes' -import { error, transformAttr } from './utils' +import validateTypes from './validateTypes.js' +import { error, transformAttr } from './utils.js' // Normalize Data export default () => ( diff --git a/src/lib/parseCompositeKey.ts b/src/lib/parseCompositeKey.ts index 95dda93ba..2ec4de613 100644 --- a/src/lib/parseCompositeKey.ts +++ b/src/lib/parseCompositeKey.ts @@ -5,14 +5,14 @@ */ import { A, O } from 'ts-toolbelt' -import { error } from './utils' -import parseMapping from './parseMapping' +import { error } from './utils.js' +import parseMapping from './parseMapping.js' import { CompositeAttributeDefinition, PureAttributeDefinition, AttributeDefinitions -} from '../classes/Entity' -import { TrackingInfo } from './parseEntity' +} from '../classes/Entity/types.js' +import { TrackingInfo } from './parseEntity.js' const parseCompositeKey = < ReadonlyAttributeDefinitions extends diff --git a/src/lib/parseEntity.ts b/src/lib/parseEntity.ts index b6c2160cf..72fc050cf 100644 --- a/src/lib/parseEntity.ts +++ b/src/lib/parseEntity.ts @@ -1,12 +1,12 @@ -import parseEntityAttributes from './parseEntityAttributes' -import type { TableDef } from '../classes/Table' +import parseEntityAttributes from './parseEntityAttributes.js' +import type { TableDef } from '../classes/Table/types.js' import type { AttributeDefinitions, EntityConstructor, PureAttributeDefinition, Readonly -} from '../classes/Entity' -import { error } from './utils' +} from '../classes/Entity/types.js' +import { error } from './utils.js' export interface TrackingInfo { fields: string[] diff --git a/src/lib/parseEntityAttributes.ts b/src/lib/parseEntityAttributes.ts index 4bf048f70..8406141e6 100644 --- a/src/lib/parseEntityAttributes.ts +++ b/src/lib/parseEntityAttributes.ts @@ -9,11 +9,11 @@ import { AttributeDefinitions, PureAttributeDefinition, CompositeAttributeDefinition -} from '../classes/Entity' -import { TrackingInfo } from './parseEntity' -import parseMapping from './parseMapping' -import parseCompositeKey from './parseCompositeKey' -import { error, typeError, validTypes, isDynamoDbType } from './utils' +} from '../classes/Entity/types.js' +import { TrackingInfo } from './parseEntity.js' +import parseMapping from './parseMapping.js' +import parseCompositeKey from './parseCompositeKey.js' +import { error, typeError, validTypes, isDynamoDbType } from './utils.js' const parseEntityAttributes = < ReadonlyAttributeDefinitions extends diff --git a/src/lib/parseMapping.ts b/src/lib/parseMapping.ts index 68c0cdaa8..441f76c32 100644 --- a/src/lib/parseMapping.ts +++ b/src/lib/parseMapping.ts @@ -10,9 +10,9 @@ import { SortKeyDefinition, GSISortKeyDefinition, PureAttributeDefinition -} from '../classes/Entity' -import { TrackingInfo } from './parseEntity' -import { error } from './utils' +} from '../classes/Entity/types.js' +import { TrackingInfo } from './parseEntity.js' +import { error } from './utils.js' // Parse and validate mapping config export default ( diff --git a/src/lib/parseTable.ts b/src/lib/parseTable.ts index eab4f9930..b046742a9 100644 --- a/src/lib/parseTable.ts +++ b/src/lib/parseTable.ts @@ -1,8 +1,8 @@ import { A } from 'ts-toolbelt' -import parseAttributes from './parseTableAttributes' -import { error, hasValue } from './utils' -import { TableConstructor, TableIndexes } from '../classes/Table' +import parseAttributes from './parseTableAttributes.js' +import { error, hasValue } from './utils.js' +import { TableConstructor, TableIndexes } from '../classes/Table/types.js' export type ParsedTable = ReturnType diff --git a/src/lib/parseTableAttributes.ts b/src/lib/parseTableAttributes.ts index bf44dbee9..05ce2c044 100644 --- a/src/lib/parseTableAttributes.ts +++ b/src/lib/parseTableAttributes.ts @@ -4,8 +4,8 @@ * @license MIT */ -import { TableAttributes, TableAttributeConfig, ParsedTableAttribute } from '../classes/Table' -import { error, typeError, keyTypeError, isDynamoDbType, isDynamoDbKeyType } from './utils' +import { TableAttributes, TableAttributeConfig, ParsedTableAttribute } from '../classes/Table/types.js' +import { error, typeError, keyTypeError, isDynamoDbType, isDynamoDbKeyType } from './utils.js' // Parse the attributes and verify valid types export default (attrs: TableAttributes, partitionKey: string, sortKey: string | null) => diff --git a/src/lib/projectionBuilder.ts b/src/lib/projectionBuilder.ts index 221672e90..c6322b2a4 100644 --- a/src/lib/projectionBuilder.ts +++ b/src/lib/projectionBuilder.ts @@ -8,9 +8,9 @@ import { A } from 'ts-toolbelt' -import { TableDef } from '../classes/Table' -import { error } from './utils' -import checkAttribute from './checkAttribute' +import { TableDef } from '../classes/Table/types.js' +import { error } from './utils.js' +import checkAttribute from './checkAttribute.js' // This should be able to parse an array with values, // or an object that uses the name of the entity plus an array of values diff --git a/src/lib/utils.ts b/src/lib/utils.ts index b14da818e..3572a87c2 100644 --- a/src/lib/utils.ts +++ b/src/lib/utils.ts @@ -1,7 +1,7 @@ import { A, L } from 'ts-toolbelt' -import { PureAttributeDefinition } from '../classes/Entity' -import { DynamoDBTypes, DynamoDBKeyTypes } from '../classes/Table' +import { PureAttributeDefinition } from '../classes/Entity/types.js' +import { DynamoDBTypes, DynamoDBKeyTypes } from '../classes/Table/types.js' import { unmarshall } from '@aws-sdk/util-dynamodb' export const validTypes: DynamoDBTypes[] = [ diff --git a/src/lib/validateTypes.ts b/src/lib/validateTypes.ts index fab69ac4c..b22d9fc1e 100644 --- a/src/lib/validateTypes.ts +++ b/src/lib/validateTypes.ts @@ -4,7 +4,7 @@ * @license MIT */ -import { toBool, hasValue, error, toDynamoBigInt, typeOf, isArrayOfSameType } from './utils' +import { toBool, hasValue, error, toDynamoBigInt, typeOf, isArrayOfSameType } from './utils.js' // Performs type validation/coercion export default () => (mapping: any, field: any, value: any) => { diff --git a/test-d/index.cjs.test-d.ts b/test-d/index.cjs.test-d.ts new file mode 100644 index 000000000..3b4ce9b98 --- /dev/null +++ b/test-d/index.cjs.test-d.ts @@ -0,0 +1 @@ +import type * as types from '../dist/cjs/index.js' diff --git a/test-d/index.esm.test-d.ts b/test-d/index.esm.test-d.ts new file mode 100644 index 000000000..e9b41cdb8 --- /dev/null +++ b/test-d/index.esm.test-d.ts @@ -0,0 +1 @@ +import type * as types from '../dist/esm/index.js' diff --git a/test-d/index.test-d.ts b/test-d/index.test-d.ts deleted file mode 100644 index b446fd7ed..000000000 --- a/test-d/index.test-d.ts +++ /dev/null @@ -1 +0,0 @@ -import type * as types from '../dist' diff --git a/tsconfig.build.json b/tsconfig.build.json deleted file mode 100644 index b1cd8e4e2..000000000 --- a/tsconfig.build.json +++ /dev/null @@ -1,4 +0,0 @@ -{ - "extends": "./tsconfig.json", - "exclude": ["node_modules", "dist", "**/*.test.ts", "**/*.test-d.ts"] -} diff --git a/tsconfig.cjs.json b/tsconfig.cjs.json new file mode 100644 index 000000000..886c71431 --- /dev/null +++ b/tsconfig.cjs.json @@ -0,0 +1,9 @@ +{ + "extends": "./tsconfig.json", + "compilerOptions": { + "moduleResolution": "node", + "module": "commonjs", + "outDir": "dist/cjs" + }, + "exclude": ["node_modules", "dist", "**/*.test.ts", "**/*.test-d.ts"] +} diff --git a/tsconfig.esm.json b/tsconfig.esm.json new file mode 100644 index 000000000..7caf2f6d1 --- /dev/null +++ b/tsconfig.esm.json @@ -0,0 +1,10 @@ +{ + "extends": "./tsconfig.json", + "compilerOptions": { + "module": "NodeNext", + "moduleResolution": "NodeNext", + "noEmitHelpers": true, + "outDir": "dist/esm" + }, + "exclude": ["node_modules", "dist", "**/*.test.ts", "**/*.test-d.ts"] +} diff --git a/tsconfig.json b/tsconfig.json index b817efa81..47235c739 100644 --- a/tsconfig.json +++ b/tsconfig.json @@ -1,11 +1,10 @@ { "compilerOptions": { + "module": "NodeNext", + "moduleResolution": "NodeNext", "baseUrl": "src", "target": "es2019", - "outDir": "dist", "rootDir": "src", - "moduleResolution": "node", - "module": "commonjs", "declaration": true, "inlineSourceMap": false, "esModuleInterop": true /* Enables emit interoperability between CommonJS and ES Modules via creation of namespace objects for all imports. Implies 'allowSyntheticDefaultImports'. */,