From 3491e420e557f061c41ad818923f07193d8ac81a Mon Sep 17 00:00:00 2001 From: Oscar Bazaldua <511911+oscb@users.noreply.github.com> Date: Thu, 4 Aug 2022 17:40:34 -0700 Subject: [PATCH] v8.0.0 (#257) --- CONTRIBUTING.md | 291 + LICENSE | 21 + Makefile | 278 - README.md | 13 + bin/dev | 18 + bin/dev.cmd | 3 + bin/run | 5 + bin/run.cmd | 3 + example/README.md | 44 - example/analytics/plan.json | 149 - example/components/Home.tsx | 59 - example/components/LoginForm.tsx | 197 - example/declarations.d.ts | 2 - example/next-env.d.ts | 2 - example/package.json | 43 - example/pages/_document.tsx | 69 - example/pages/home.tsx | 20 - example/pages/index.tsx | 1 - example/pages/login.tsx | 61 - example/tests/login.test.js | 19 - example/tests/setup-tests.js | 4 - example/tsconfig.json | 24 - example/typewriter.yml | 18 - example/yarn.lock | 6877 ---------- package.json | 250 +- src/@types/ink-link.d.ts | 9 - src/@types/ink-spinner.d.ts | 10 - src/@types/sort-keys.d.ts | 1 - src/@types/types.d.ts | 9 - src/analytics/README.md | 5 - src/analytics/plan.json | 172 - src/api/api.ts | 234 + src/api/index.ts | 8 + src/api/trackingplans.ts | 181 + src/base-command.ts | 158 + src/cli/api/api.ts | 178 - src/cli/api/index.ts | 10 - src/cli/api/trackingplans.ts | 130 - src/cli/commands/build.tsx | 507 - src/cli/commands/error.tsx | 190 - src/cli/commands/help.tsx | 170 - src/cli/commands/index.ts | 6 - src/cli/commands/init.tsx | 807 -- src/cli/commands/token.tsx | 78 - src/cli/commands/version.tsx | 56 - src/cli/config/config.ts | 193 - src/cli/config/index.ts | 14 - src/cli/config/schema.ts | 95 - src/cli/config/scripts.ts | 33 - src/cli/config/typewriter.yml.hbs | 24 - src/cli/index.tsx | 320 - src/commands/build.ts | 189 + src/commands/development.ts | 24 + src/commands/help.ts | 33 + src/commands/init.ts | 421 + src/commands/production.ts | 24 + src/commands/start.ts | 23 + src/commands/token.ts | 49 + src/commands/update.ts | 42 + src/commands/version.ts | 45 + src/common/error.ts | 19 + src/common/index.ts | 1 + src/common/ttys.ts | 25 + src/config/auth.ts | 3 + src/config/config.ts | 278 + src/config/index.ts | 16 + src/config/schema.ts | 106 + src/config/scripts.ts | 37 + src/generators/android/android.ts | 155 - src/generators/android/index.ts | 1 - .../templates/SerializableProperties.java.hbs | 11 - .../templates/TypewriterAnalytics.java.hbs | 88 - .../templates/TypewriterUtils.java.hbs | 52 - .../android/templates/class.java.hbs | 82 - src/generators/ast.ts | 277 - src/generators/gen.ts | 343 - src/generators/javascript/index.ts | 1 - src/generators/javascript/javascript.ts | 200 - src/generators/javascript/targets.ts | 55 - .../templates/functionDocumentation.hbs | 20 - src/generators/javascript/templates/index.hbs | 287 - .../javascript/templates/segment.hbs | 134 - .../setTypewriterOptionsDocumentation.hbs | 17 - src/generators/namer.ts | 152 - src/generators/objc/index.ts | 1 - src/generators/objc/objc.ts | 321 - .../templates/SEGTypewriterSerializable.h.hbs | 12 - .../objc/templates/SEGTypewriterUtils.h.hbs | 14 - .../objc/templates/SEGTypewriterUtils.m.hbs | 54 - src/generators/objc/templates/analytics.h.hbs | 27 - src/generators/objc/templates/analytics.m.hbs | 31 - src/generators/objc/templates/class.h.hbs | 26 - src/generators/objc/templates/class.m.hbs | 23 - src/generators/options.ts | 60 - src/generators/swift/index.ts | 1 - src/generators/swift/swift.ts | 294 - .../TypewriterSerializable.swift.hbs | 9 - .../swift/templates/TypewriterUtils.swift.hbs | 45 - .../swift/templates/analytics.swift.hbs | 31 - .../swift/templates/class.swift.hbs | 26 - src/help.ts | 38 + src/hooks/postrun/telemetry.ts | 9 + src/hooks/prerun/load-languages.ts | 9 + src/index.ts | 1 + src/languages/common.ts | 0 src/languages/index.ts | 9 + src/languages/javascript.ts | 82 + src/languages/kotlin.ts | 102 + src/languages/quicktype-utils.ts | 525 + src/languages/swift.ts | 103 + src/languages/templates/kotlin/kotlin.hbs | 5 + src/languages/templates/swift/analytics.hbs | 9 + .../templates/typescript/analytics-js.hbs | 284 + src/languages/templates/typescript/node.hbs | 333 + .../templates/typescript/react-native.hbs | 60 + src/languages/types.ts | 89 + src/languages/typescript.ts | 103 + src/telemetry/index.ts | 124 + src/telemetry/plan.json | 476 + src/telemetry/segment.ts | 745 ++ src/templates.ts | 72 - test/commands/build.test.ts | 17 + test/commands/development.test.ts | 17 + test/commands/help.test.ts | 17 + test/commands/index.test.ts | 17 + test/commands/init.test.ts | 17 + test/commands/production.test.ts | 17 + test/commands/token.test.ts | 17 + test/commands/typescript.test.ts | 17 + test/commands/update.test.ts | 17 + test/commands/version.test.ts | 10 + test/helpers/init.js | 6 + test/hooks/init/load-languages.test.ts | 9 + test/hooks/postrun/telemetry.test.ts | 9 + test/tsconfig.json | 9 + tests/ast.test.ts | 25 - tests/e2e/android-java/.gitignore | 14 - tests/e2e/android-java/.idea/.name | 1 - .../android-java/.idea/codeStyles/Project.xml | 116 - tests/e2e/android-java/.idea/gradle.xml | 21 - tests/e2e/android-java/.idea/misc.xml | 9 - .../android-java/.idea/runConfigurations.xml | 12 - tests/e2e/android-java/.idea/vcs.xml | 6 - tests/e2e/android-java/.project | 17 - .../org.eclipse.buildship.core.prefs | 13 - tests/e2e/android-java/app/.classpath | 6 - tests/e2e/android-java/app/.gitignore | 1 - tests/e2e/android-java/app/.project | 17 - .../org.eclipse.buildship.core.prefs | 2 - tests/e2e/android-java/app/build.gradle | 41 - tests/e2e/android-java/app/proguard-rules.pro | 21 - .../app/src/main/AndroidManifest.xml | 31 - .../DisplayMessageActivity.java | 30 - .../TypewriterJavaExample/MainActivity.java | 75 - .../TypewriterApplication.java | 19 - .../generated/CustomViolationHandler.java | 54 - .../generated/DefaultViolationHandler.java | 54 - .../java/com/segment/generated/EnumTypes.java | 62 - .../generated/EveryNullableOptionalType.java | 148 - .../generated/EveryNullableRequiredType.java | 148 - .../segment/generated/EveryOptionalType.java | 148 - .../segment/generated/EveryRequiredType.java | 175 - .../java/com/segment/generated/Garage.java | 58 - .../segment/generated/LargeNumbersEvent.java | 120 - .../com/segment/generated/NestedArrays.java | 56 - .../com/segment/generated/NestedObjects.java | 58 - .../com/segment/generated/ObjectItem.java | 51 - .../com/segment/generated/OccupantsItem.java | 55 - .../com/segment/generated/OccupantsItem1.java | 55 - .../OptionalArrayWithPropertiesItem.java | 123 - .../OptionalArrayWithPropertiesItem1.java | 123 - .../OptionalObjectWithProperties.java | 123 - .../OptionalObjectWithProperties1.java | 123 - .../segment/generated/PropertiesCollided.java | 66 - .../PropertyObjectNameCollision1.java | 55 - .../PropertyObjectNameCollision2.java | 55 - .../segment/generated/PropertySanitized.java | 54 - .../RequiredArrayWithPropertiesItem.java | 123 - .../RequiredArrayWithPropertiesItem1.java | 144 - .../RequiredObjectWithProperties.java | 123 - .../RequiredObjectWithProperties1.java | 144 - .../generated/SerializableProperties.java | 11 - .../segment/generated/SimpleArrayTypes.java | 112 - .../segment/generated/SubterraneanLab.java | 71 - .../java/com/segment/generated/Tunnel.java | 58 - .../generated/TypewriterAnalytics.java | 435 - .../segment/generated/TypewriterUtils.java | 52 - .../java/com/segment/generated/UnionType.java | 51 - .../java/com/segment/generated/Universe.java | 69 - .../java/com/segment/generated/Universe1.java | 69 - .../generated/UniverseCharactersItemItem.java | 55 - .../main/java/com/segment/generated/plan.json | 1281 -- .../drawable-v24/ic_launcher_foreground.xml | 34 - .../res/drawable/ic_launcher_background.xml | 74 - .../layout-v26/activity_display_message.xml | 23 - .../src/main/res/layout-v26/activity_main.xml | 27 - .../res/layout/activity_display_message.xml | 24 - .../app/src/main/res/layout/activity_main.xml | 27 - .../res/mipmap-anydpi-v26/ic_launcher.xml | 5 - .../mipmap-anydpi-v26/ic_launcher_round.xml | 5 - .../src/main/res/mipmap-hdpi/ic_launcher.png | Bin 2963 -> 0 bytes .../res/mipmap-hdpi/ic_launcher_round.png | Bin 4905 -> 0 bytes .../src/main/res/mipmap-mdpi/ic_launcher.png | Bin 2060 -> 0 bytes .../res/mipmap-mdpi/ic_launcher_round.png | Bin 2783 -> 0 bytes .../src/main/res/mipmap-xhdpi/ic_launcher.png | Bin 4490 -> 0 bytes .../res/mipmap-xhdpi/ic_launcher_round.png | Bin 6895 -> 0 bytes .../main/res/mipmap-xxhdpi/ic_launcher.png | Bin 6387 -> 0 bytes .../res/mipmap-xxhdpi/ic_launcher_round.png | Bin 10413 -> 0 bytes .../main/res/mipmap-xxxhdpi/ic_launcher.png | Bin 9128 -> 0 bytes .../res/mipmap-xxxhdpi/ic_launcher_round.png | Bin 15132 -> 0 bytes .../app/src/main/res/values/colors.xml | 6 - .../app/src/main/res/values/strings.xml | 5 - .../app/src/main/res/values/styles.xml | 11 - .../ExampleUnitTest.java | 456 - .../TypewriterJavaExample/TestApp.java | 27 - tests/e2e/android-java/build.gradle | 27 - tests/e2e/android-java/gradle.properties | 21 - .../gradle/wrapper/gradle-wrapper.jar | Bin 54329 -> 0 bytes .../gradle/wrapper/gradle-wrapper.properties | 6 - tests/e2e/android-java/gradlew | 172 - tests/e2e/android-java/gradlew.bat | 84 - tests/e2e/android-java/settings.gradle | 2 - tests/e2e/android-java/typewriter.yml | 18 - tests/e2e/docker-compose.yml | 11 - tests/e2e/ios-objc/.gitignore | 58 - tests/e2e/ios-objc/Podfile | 13 - tests/e2e/ios-objc/Podfile.lock | 16 - .../project.pbxproj | 741 -- .../contents.xcworkspacedata | 7 - .../contents.xcworkspacedata | 10 - .../xcshareddata/IDEWorkspaceChecks.plist | 8 - .../TypewriterExample/Analytics/SEGGarage.h | 19 - .../TypewriterExample/Analytics/SEGGarage.m | 24 - .../Analytics/SEGObjectItem.h | 18 - .../Analytics/SEGObjectItem.m | 24 - .../Analytics/SEGOccupantsItem.h | 19 - .../Analytics/SEGOccupantsItem.m | 24 - .../Analytics/SEGOccupantsItem1.h | 19 - .../Analytics/SEGOccupantsItem1.m | 24 - .../SEGOptionalArrayWithPropertiesItem.h | 40 - .../SEGOptionalArrayWithPropertiesItem.m | 59 - .../SEGOptionalArrayWithPropertiesItem1.h | 40 - .../SEGOptionalArrayWithPropertiesItem1.m | 59 - .../SEGOptionalObjectWithProperties.h | 40 - .../SEGOptionalObjectWithProperties.m | 59 - .../SEGOptionalObjectWithProperties1.h | 40 - .../SEGOptionalObjectWithProperties1.m | 59 - .../SEGRequiredArrayWithPropertiesItem.h | 40 - .../SEGRequiredArrayWithPropertiesItem.m | 43 - .../SEGRequiredArrayWithPropertiesItem1.h | 40 - .../SEGRequiredArrayWithPropertiesItem1.m | 53 - .../SEGRequiredObjectWithProperties.h | 40 - .../SEGRequiredObjectWithProperties.m | 43 - .../SEGRequiredObjectWithProperties1.h | 40 - .../SEGRequiredObjectWithProperties1.m | 53 - .../Analytics/SEGSubterraneanLab.h | 22 - .../Analytics/SEGSubterraneanLab.m | 34 - .../TypewriterExample/Analytics/SEGTunnel.h | 19 - .../TypewriterExample/Analytics/SEGTunnel.m | 24 - .../Analytics/SEGTypewriterAnalytics.h | 234 - .../Analytics/SEGTypewriterAnalytics.m | 562 - .../Analytics/SEGTypewriterSerializable.h | 12 - .../Analytics/SEGTypewriterUtils.h | 14 - .../Analytics/SEGTypewriterUtils.m | 54 - .../TypewriterExample/Analytics/SEGUniverse.h | 23 - .../TypewriterExample/Analytics/SEGUniverse.m | 29 - .../Analytics/SEGUniverse1.h | 23 - .../Analytics/SEGUniverse1.m | 29 - .../Analytics/SEGUniverseCharactersItemItem.h | 19 - .../Analytics/SEGUniverseCharactersItemItem.m | 24 - .../TypewriterExample/Analytics/plan.json | 1250 -- .../ios-objc/TypewriterExample/AppDelegate.h | 17 - .../ios-objc/TypewriterExample/AppDelegate.m | 42 - .../e2e/ios-objc/TypewriterExample/Info.plist | 56 - tests/e2e/ios-objc/TypewriterExample/main.m | 18 - .../TypewriterExampleTests/Info.plist | 27 - .../TypewriterExampleTests.m | 265 - tests/e2e/ios-objc/typewriter.yml | 18 - tests/e2e/ios-swift/.gitignore | 58 - tests/e2e/ios-swift/Podfile | 11 - tests/e2e/ios-swift/Podfile.lock | 16 - .../project.pbxproj | 668 - .../contents.xcworkspacedata | 7 - .../xcshareddata/IDEWorkspaceChecks.plist | 8 - .../contents.xcworkspacedata | 10 - .../xcshareddata/IDEWorkspaceChecks.plist | 8 - .../Analytics/Garage.swift | 20 - .../Analytics/ObjectItem.swift | 20 - .../Analytics/OccupantsItem.swift | 21 - .../Analytics/OccupantsItem1.swift | 21 - .../OptionalArrayWithPropertiesItem.swift | 49 - .../OptionalArrayWithPropertiesItem1.swift | 49 - .../OptionalObjectWithProperties.swift | 49 - .../OptionalObjectWithProperties1.swift | 49 - .../RequiredArrayWithPropertiesItem.swift | 49 - .../RequiredArrayWithPropertiesItem1.swift | 49 - .../RequiredObjectWithProperties.swift | 49 - .../RequiredObjectWithProperties1.swift | 49 - .../Analytics/SubterraneanLab.swift | 26 - .../Analytics/Tunnel.swift | 20 - .../Analytics/TypewriterAnalytics.swift | 343 - .../Analytics/TypewriterSerializable.swift | 9 - .../Analytics/TypewriterUtils.swift | 45 - .../Analytics/Universe.swift | 25 - .../Analytics/Universe1.swift | 25 - .../UniverseCharactersItemItem.swift | 21 - .../Analytics/plan.json | 1281 -- .../TypewriterSwiftExample/AppDelegate.swift | 40 - .../AppIcon.appiconset/Contents.json | 98 - .../Assets.xcassets/Contents.json | 6 - .../Base.lproj/LaunchScreen.storyboard | 25 - .../Base.lproj/Main.storyboard | 24 - .../TypewriterSwiftExample/Info.plist | 50 - .../ViewController.swift | 18 - .../TypewriterSwiftExampleTests/Info.plist | 27 - .../TypewriterSwiftExampleTests.swift | 253 - tests/e2e/ios-swift/typewriter.yml | 18 - tests/e2e/node-javascript/analytics/index.js | 2291 ---- tests/e2e/node-javascript/analytics/plan.json | 1250 -- tests/e2e/node-javascript/index.js | 506 - tests/e2e/node-javascript/package.json | 16 - tests/e2e/node-javascript/typewriter.yml | 20 - tests/e2e/node-javascript/yarn.lock | 103 - tests/e2e/node-typescript/analytics/index.ts | 2962 ----- tests/e2e/node-typescript/analytics/plan.json | 1250 -- .../e2e/node-typescript/analytics/segment.ts | 120 - tests/e2e/node-typescript/index.ts | 508 - tests/e2e/node-typescript/package.json | 21 - tests/e2e/node-typescript/typewriter.yml | 18 - tests/e2e/node-typescript/yarn.lock | 162 - tests/e2e/suite.test.ts | 667 - tests/e2e/web-javascript/analytics/index.js | 2334 ---- tests/e2e/web-javascript/analytics/plan.json | 1250 -- tests/e2e/web-javascript/cypress.json | 1 - .../cypress/integration/suite.js | 23 - tests/e2e/web-javascript/package.json | 31 - tests/e2e/web-javascript/pages/_document.jsx | 37 - tests/e2e/web-javascript/pages/index.jsx | 388 - tests/e2e/web-javascript/typewriter.yml | 18 - tests/e2e/web-javascript/yarn.lock | 5587 -------- tests/e2e/web-typescript/analytics/index.ts | 3033 ----- tests/e2e/web-typescript/analytics/plan.json | 1250 -- tests/e2e/web-typescript/analytics/segment.ts | 103 - tests/e2e/web-typescript/cypress.json | 1 - .../cypress/integration/suite.js | 23 - tests/e2e/web-typescript/declarations.d.ts | 1 - tests/e2e/web-typescript/next.config.js | 12 - tests/e2e/web-typescript/package.json | 50 - tests/e2e/web-typescript/pages/_document.tsx | 37 - tests/e2e/web-typescript/pages/index.tsx | 392 - tests/e2e/web-typescript/tsconfig.json | 17 - tests/e2e/web-typescript/typewriter.yml | 18 - tests/e2e/web-typescript/yarn.lock | 6830 ---------- tests/fixtures/asts.ts | 296 - tests/fixtures/schemas/basicTypes.json | 29 - tests/fixtures/schemas/enums.json | 21 - tests/fixtures/schemas/nested.json | 28 - tests/fixtures/schemas/nulls.json | 30 - tests/fixtures/schemas/required.json | 26 - tests/fixtures/schemas/unions.json | 31 - tests/namer.test.ts | 115 - tsconfig.json | 24 +- typewriter.yml | 25 +- yarn.lock | 10542 +++++++--------- 364 files changed, 10251 insertions(+), 66379 deletions(-) create mode 100644 CONTRIBUTING.md create mode 100644 LICENSE delete mode 100644 Makefile create mode 100755 bin/dev create mode 100644 bin/dev.cmd create mode 100755 bin/run create mode 100644 bin/run.cmd delete mode 100644 example/README.md delete mode 100644 example/analytics/plan.json delete mode 100644 example/components/Home.tsx delete mode 100644 example/components/LoginForm.tsx delete mode 100644 example/declarations.d.ts delete mode 100644 example/next-env.d.ts delete mode 100644 example/package.json delete mode 100644 example/pages/_document.tsx delete mode 100644 example/pages/home.tsx delete mode 100644 example/pages/index.tsx delete mode 100644 example/pages/login.tsx delete mode 100644 example/tests/login.test.js delete mode 100644 example/tests/setup-tests.js delete mode 100644 example/tsconfig.json delete mode 100644 example/typewriter.yml delete mode 100644 example/yarn.lock delete mode 100644 src/@types/ink-link.d.ts delete mode 100644 src/@types/ink-spinner.d.ts delete mode 100644 src/@types/sort-keys.d.ts delete mode 100644 src/@types/types.d.ts delete mode 100644 src/analytics/README.md delete mode 100644 src/analytics/plan.json create mode 100644 src/api/api.ts create mode 100644 src/api/index.ts create mode 100644 src/api/trackingplans.ts create mode 100644 src/base-command.ts delete mode 100644 src/cli/api/api.ts delete mode 100644 src/cli/api/index.ts delete mode 100644 src/cli/api/trackingplans.ts delete mode 100644 src/cli/commands/build.tsx delete mode 100644 src/cli/commands/error.tsx delete mode 100644 src/cli/commands/help.tsx delete mode 100644 src/cli/commands/index.ts delete mode 100644 src/cli/commands/init.tsx delete mode 100644 src/cli/commands/token.tsx delete mode 100644 src/cli/commands/version.tsx delete mode 100644 src/cli/config/config.ts delete mode 100644 src/cli/config/index.ts delete mode 100644 src/cli/config/schema.ts delete mode 100644 src/cli/config/scripts.ts delete mode 100644 src/cli/config/typewriter.yml.hbs delete mode 100644 src/cli/index.tsx create mode 100644 src/commands/build.ts create mode 100644 src/commands/development.ts create mode 100644 src/commands/help.ts create mode 100644 src/commands/init.ts create mode 100644 src/commands/production.ts create mode 100644 src/commands/start.ts create mode 100644 src/commands/token.ts create mode 100644 src/commands/update.ts create mode 100644 src/commands/version.ts create mode 100644 src/common/error.ts create mode 100644 src/common/index.ts create mode 100644 src/common/ttys.ts create mode 100644 src/config/auth.ts create mode 100644 src/config/config.ts create mode 100644 src/config/index.ts create mode 100644 src/config/schema.ts create mode 100644 src/config/scripts.ts delete mode 100644 src/generators/android/android.ts delete mode 100644 src/generators/android/index.ts delete mode 100644 src/generators/android/templates/SerializableProperties.java.hbs delete mode 100644 src/generators/android/templates/TypewriterAnalytics.java.hbs delete mode 100644 src/generators/android/templates/TypewriterUtils.java.hbs delete mode 100644 src/generators/android/templates/class.java.hbs delete mode 100644 src/generators/ast.ts delete mode 100644 src/generators/gen.ts delete mode 100644 src/generators/javascript/index.ts delete mode 100644 src/generators/javascript/javascript.ts delete mode 100644 src/generators/javascript/targets.ts delete mode 100644 src/generators/javascript/templates/functionDocumentation.hbs delete mode 100644 src/generators/javascript/templates/index.hbs delete mode 100644 src/generators/javascript/templates/segment.hbs delete mode 100644 src/generators/javascript/templates/setTypewriterOptionsDocumentation.hbs delete mode 100644 src/generators/namer.ts delete mode 100644 src/generators/objc/index.ts delete mode 100644 src/generators/objc/objc.ts delete mode 100644 src/generators/objc/templates/SEGTypewriterSerializable.h.hbs delete mode 100644 src/generators/objc/templates/SEGTypewriterUtils.h.hbs delete mode 100644 src/generators/objc/templates/SEGTypewriterUtils.m.hbs delete mode 100644 src/generators/objc/templates/analytics.h.hbs delete mode 100644 src/generators/objc/templates/analytics.m.hbs delete mode 100644 src/generators/objc/templates/class.h.hbs delete mode 100644 src/generators/objc/templates/class.m.hbs delete mode 100644 src/generators/options.ts delete mode 100644 src/generators/swift/index.ts delete mode 100644 src/generators/swift/swift.ts delete mode 100644 src/generators/swift/templates/TypewriterSerializable.swift.hbs delete mode 100644 src/generators/swift/templates/TypewriterUtils.swift.hbs delete mode 100644 src/generators/swift/templates/analytics.swift.hbs delete mode 100644 src/generators/swift/templates/class.swift.hbs create mode 100644 src/help.ts create mode 100644 src/hooks/postrun/telemetry.ts create mode 100644 src/hooks/prerun/load-languages.ts create mode 100644 src/index.ts create mode 100644 src/languages/common.ts create mode 100644 src/languages/index.ts create mode 100644 src/languages/javascript.ts create mode 100644 src/languages/kotlin.ts create mode 100644 src/languages/quicktype-utils.ts create mode 100644 src/languages/swift.ts create mode 100644 src/languages/templates/kotlin/kotlin.hbs create mode 100644 src/languages/templates/swift/analytics.hbs create mode 100644 src/languages/templates/typescript/analytics-js.hbs create mode 100644 src/languages/templates/typescript/node.hbs create mode 100644 src/languages/templates/typescript/react-native.hbs create mode 100644 src/languages/types.ts create mode 100644 src/languages/typescript.ts create mode 100644 src/telemetry/index.ts create mode 100644 src/telemetry/plan.json create mode 100644 src/telemetry/segment.ts delete mode 100644 src/templates.ts create mode 100644 test/commands/build.test.ts create mode 100644 test/commands/development.test.ts create mode 100644 test/commands/help.test.ts create mode 100644 test/commands/index.test.ts create mode 100644 test/commands/init.test.ts create mode 100644 test/commands/production.test.ts create mode 100644 test/commands/token.test.ts create mode 100644 test/commands/typescript.test.ts create mode 100644 test/commands/update.test.ts create mode 100644 test/commands/version.test.ts create mode 100644 test/helpers/init.js create mode 100644 test/hooks/init/load-languages.test.ts create mode 100644 test/hooks/postrun/telemetry.test.ts create mode 100644 test/tsconfig.json delete mode 100644 tests/ast.test.ts delete mode 100644 tests/e2e/android-java/.gitignore delete mode 100644 tests/e2e/android-java/.idea/.name delete mode 100644 tests/e2e/android-java/.idea/codeStyles/Project.xml delete mode 100644 tests/e2e/android-java/.idea/gradle.xml delete mode 100644 tests/e2e/android-java/.idea/misc.xml delete mode 100644 tests/e2e/android-java/.idea/runConfigurations.xml delete mode 100644 tests/e2e/android-java/.idea/vcs.xml delete mode 100644 tests/e2e/android-java/.project delete mode 100644 tests/e2e/android-java/.settings/org.eclipse.buildship.core.prefs delete mode 100644 tests/e2e/android-java/app/.classpath delete mode 100644 tests/e2e/android-java/app/.gitignore delete mode 100644 tests/e2e/android-java/app/.project delete mode 100644 tests/e2e/android-java/app/.settings/org.eclipse.buildship.core.prefs delete mode 100644 tests/e2e/android-java/app/build.gradle delete mode 100644 tests/e2e/android-java/app/proguard-rules.pro delete mode 100644 tests/e2e/android-java/app/src/main/AndroidManifest.xml delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/TypewriterJavaExample/DisplayMessageActivity.java delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/TypewriterJavaExample/MainActivity.java delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/TypewriterJavaExample/TypewriterApplication.java delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/generated/CustomViolationHandler.java delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/generated/DefaultViolationHandler.java delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/generated/EnumTypes.java delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/generated/EveryNullableOptionalType.java delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/generated/EveryNullableRequiredType.java delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/generated/EveryOptionalType.java delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/generated/EveryRequiredType.java delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/generated/Garage.java delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/generated/LargeNumbersEvent.java delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/generated/NestedArrays.java delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/generated/NestedObjects.java delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/generated/ObjectItem.java delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/generated/OccupantsItem.java delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/generated/OccupantsItem1.java delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/generated/OptionalArrayWithPropertiesItem.java delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/generated/OptionalArrayWithPropertiesItem1.java delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/generated/OptionalObjectWithProperties.java delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/generated/OptionalObjectWithProperties1.java delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/generated/PropertiesCollided.java delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/generated/PropertyObjectNameCollision1.java delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/generated/PropertyObjectNameCollision2.java delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/generated/PropertySanitized.java delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/generated/RequiredArrayWithPropertiesItem.java delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/generated/RequiredArrayWithPropertiesItem1.java delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/generated/RequiredObjectWithProperties.java delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/generated/RequiredObjectWithProperties1.java delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/generated/SerializableProperties.java delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/generated/SimpleArrayTypes.java delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/generated/SubterraneanLab.java delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/generated/Tunnel.java delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/generated/TypewriterAnalytics.java delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/generated/TypewriterUtils.java delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/generated/UnionType.java delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/generated/Universe.java delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/generated/Universe1.java delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/generated/UniverseCharactersItemItem.java delete mode 100644 tests/e2e/android-java/app/src/main/java/com/segment/generated/plan.json delete mode 100644 tests/e2e/android-java/app/src/main/res/drawable-v24/ic_launcher_foreground.xml delete mode 100644 tests/e2e/android-java/app/src/main/res/drawable/ic_launcher_background.xml delete mode 100644 tests/e2e/android-java/app/src/main/res/layout-v26/activity_display_message.xml delete mode 100644 tests/e2e/android-java/app/src/main/res/layout-v26/activity_main.xml delete mode 100644 tests/e2e/android-java/app/src/main/res/layout/activity_display_message.xml delete mode 100644 tests/e2e/android-java/app/src/main/res/layout/activity_main.xml delete mode 100644 tests/e2e/android-java/app/src/main/res/mipmap-anydpi-v26/ic_launcher.xml delete mode 100644 tests/e2e/android-java/app/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml delete mode 100644 tests/e2e/android-java/app/src/main/res/mipmap-hdpi/ic_launcher.png delete mode 100644 tests/e2e/android-java/app/src/main/res/mipmap-hdpi/ic_launcher_round.png delete mode 100644 tests/e2e/android-java/app/src/main/res/mipmap-mdpi/ic_launcher.png delete mode 100644 tests/e2e/android-java/app/src/main/res/mipmap-mdpi/ic_launcher_round.png delete mode 100644 tests/e2e/android-java/app/src/main/res/mipmap-xhdpi/ic_launcher.png delete mode 100644 tests/e2e/android-java/app/src/main/res/mipmap-xhdpi/ic_launcher_round.png delete mode 100644 tests/e2e/android-java/app/src/main/res/mipmap-xxhdpi/ic_launcher.png delete mode 100644 tests/e2e/android-java/app/src/main/res/mipmap-xxhdpi/ic_launcher_round.png delete mode 100644 tests/e2e/android-java/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png delete mode 100644 tests/e2e/android-java/app/src/main/res/mipmap-xxxhdpi/ic_launcher_round.png delete mode 100644 tests/e2e/android-java/app/src/main/res/values/colors.xml delete mode 100644 tests/e2e/android-java/app/src/main/res/values/strings.xml delete mode 100644 tests/e2e/android-java/app/src/main/res/values/styles.xml delete mode 100644 tests/e2e/android-java/app/src/test/java/com/segment/TypewriterJavaExample/ExampleUnitTest.java delete mode 100644 tests/e2e/android-java/app/src/test/java/com/segment/TypewriterJavaExample/TestApp.java delete mode 100644 tests/e2e/android-java/build.gradle delete mode 100644 tests/e2e/android-java/gradle.properties delete mode 100644 tests/e2e/android-java/gradle/wrapper/gradle-wrapper.jar delete mode 100644 tests/e2e/android-java/gradle/wrapper/gradle-wrapper.properties delete mode 100755 tests/e2e/android-java/gradlew delete mode 100644 tests/e2e/android-java/gradlew.bat delete mode 100644 tests/e2e/android-java/settings.gradle delete mode 100644 tests/e2e/android-java/typewriter.yml delete mode 100644 tests/e2e/docker-compose.yml delete mode 100644 tests/e2e/ios-objc/.gitignore delete mode 100755 tests/e2e/ios-objc/Podfile delete mode 100755 tests/e2e/ios-objc/Podfile.lock delete mode 100644 tests/e2e/ios-objc/TypewriterExample.xcodeproj/project.pbxproj delete mode 100755 tests/e2e/ios-objc/TypewriterExample.xcodeproj/project.xcworkspace/contents.xcworkspacedata delete mode 100755 tests/e2e/ios-objc/TypewriterExample.xcworkspace/contents.xcworkspacedata delete mode 100755 tests/e2e/ios-objc/TypewriterExample.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/SEGGarage.h delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/SEGGarage.m delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/SEGObjectItem.h delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/SEGObjectItem.m delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/SEGOccupantsItem.h delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/SEGOccupantsItem.m delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/SEGOccupantsItem1.h delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/SEGOccupantsItem1.m delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/SEGOptionalArrayWithPropertiesItem.h delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/SEGOptionalArrayWithPropertiesItem.m delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/SEGOptionalArrayWithPropertiesItem1.h delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/SEGOptionalArrayWithPropertiesItem1.m delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/SEGOptionalObjectWithProperties.h delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/SEGOptionalObjectWithProperties.m delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/SEGOptionalObjectWithProperties1.h delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/SEGOptionalObjectWithProperties1.m delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/SEGRequiredArrayWithPropertiesItem.h delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/SEGRequiredArrayWithPropertiesItem.m delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/SEGRequiredArrayWithPropertiesItem1.h delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/SEGRequiredArrayWithPropertiesItem1.m delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/SEGRequiredObjectWithProperties.h delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/SEGRequiredObjectWithProperties.m delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/SEGRequiredObjectWithProperties1.h delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/SEGRequiredObjectWithProperties1.m delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/SEGSubterraneanLab.h delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/SEGSubterraneanLab.m delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/SEGTunnel.h delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/SEGTunnel.m delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/SEGTypewriterAnalytics.h delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/SEGTypewriterAnalytics.m delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/SEGTypewriterSerializable.h delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/SEGTypewriterUtils.h delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/SEGTypewriterUtils.m delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/SEGUniverse.h delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/SEGUniverse.m delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/SEGUniverse1.h delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/SEGUniverse1.m delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/SEGUniverseCharactersItemItem.h delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/SEGUniverseCharactersItemItem.m delete mode 100644 tests/e2e/ios-objc/TypewriterExample/Analytics/plan.json delete mode 100755 tests/e2e/ios-objc/TypewriterExample/AppDelegate.h delete mode 100755 tests/e2e/ios-objc/TypewriterExample/AppDelegate.m delete mode 100755 tests/e2e/ios-objc/TypewriterExample/Info.plist delete mode 100755 tests/e2e/ios-objc/TypewriterExample/main.m delete mode 100644 tests/e2e/ios-objc/TypewriterExampleTests/Info.plist delete mode 100644 tests/e2e/ios-objc/TypewriterExampleTests/TypewriterExampleTests.m delete mode 100644 tests/e2e/ios-objc/typewriter.yml delete mode 100644 tests/e2e/ios-swift/.gitignore delete mode 100644 tests/e2e/ios-swift/Podfile delete mode 100644 tests/e2e/ios-swift/Podfile.lock delete mode 100644 tests/e2e/ios-swift/TypewriterSwiftExample.xcodeproj/project.pbxproj delete mode 100644 tests/e2e/ios-swift/TypewriterSwiftExample.xcodeproj/project.xcworkspace/contents.xcworkspacedata delete mode 100644 tests/e2e/ios-swift/TypewriterSwiftExample.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist delete mode 100644 tests/e2e/ios-swift/TypewriterSwiftExample.xcworkspace/contents.xcworkspacedata delete mode 100644 tests/e2e/ios-swift/TypewriterSwiftExample.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist delete mode 100644 tests/e2e/ios-swift/TypewriterSwiftExample/Analytics/Garage.swift delete mode 100644 tests/e2e/ios-swift/TypewriterSwiftExample/Analytics/ObjectItem.swift delete mode 100644 tests/e2e/ios-swift/TypewriterSwiftExample/Analytics/OccupantsItem.swift delete mode 100644 tests/e2e/ios-swift/TypewriterSwiftExample/Analytics/OccupantsItem1.swift delete mode 100644 tests/e2e/ios-swift/TypewriterSwiftExample/Analytics/OptionalArrayWithPropertiesItem.swift delete mode 100644 tests/e2e/ios-swift/TypewriterSwiftExample/Analytics/OptionalArrayWithPropertiesItem1.swift delete mode 100644 tests/e2e/ios-swift/TypewriterSwiftExample/Analytics/OptionalObjectWithProperties.swift delete mode 100644 tests/e2e/ios-swift/TypewriterSwiftExample/Analytics/OptionalObjectWithProperties1.swift delete mode 100644 tests/e2e/ios-swift/TypewriterSwiftExample/Analytics/RequiredArrayWithPropertiesItem.swift delete mode 100644 tests/e2e/ios-swift/TypewriterSwiftExample/Analytics/RequiredArrayWithPropertiesItem1.swift delete mode 100644 tests/e2e/ios-swift/TypewriterSwiftExample/Analytics/RequiredObjectWithProperties.swift delete mode 100644 tests/e2e/ios-swift/TypewriterSwiftExample/Analytics/RequiredObjectWithProperties1.swift delete mode 100644 tests/e2e/ios-swift/TypewriterSwiftExample/Analytics/SubterraneanLab.swift delete mode 100644 tests/e2e/ios-swift/TypewriterSwiftExample/Analytics/Tunnel.swift delete mode 100644 tests/e2e/ios-swift/TypewriterSwiftExample/Analytics/TypewriterAnalytics.swift delete mode 100644 tests/e2e/ios-swift/TypewriterSwiftExample/Analytics/TypewriterSerializable.swift delete mode 100644 tests/e2e/ios-swift/TypewriterSwiftExample/Analytics/TypewriterUtils.swift delete mode 100644 tests/e2e/ios-swift/TypewriterSwiftExample/Analytics/Universe.swift delete mode 100644 tests/e2e/ios-swift/TypewriterSwiftExample/Analytics/Universe1.swift delete mode 100644 tests/e2e/ios-swift/TypewriterSwiftExample/Analytics/UniverseCharactersItemItem.swift delete mode 100644 tests/e2e/ios-swift/TypewriterSwiftExample/Analytics/plan.json delete mode 100644 tests/e2e/ios-swift/TypewriterSwiftExample/AppDelegate.swift delete mode 100644 tests/e2e/ios-swift/TypewriterSwiftExample/Assets.xcassets/AppIcon.appiconset/Contents.json delete mode 100644 tests/e2e/ios-swift/TypewriterSwiftExample/Assets.xcassets/Contents.json delete mode 100644 tests/e2e/ios-swift/TypewriterSwiftExample/Base.lproj/LaunchScreen.storyboard delete mode 100644 tests/e2e/ios-swift/TypewriterSwiftExample/Base.lproj/Main.storyboard delete mode 100644 tests/e2e/ios-swift/TypewriterSwiftExample/Info.plist delete mode 100644 tests/e2e/ios-swift/TypewriterSwiftExample/ViewController.swift delete mode 100644 tests/e2e/ios-swift/TypewriterSwiftExampleTests/Info.plist delete mode 100644 tests/e2e/ios-swift/TypewriterSwiftExampleTests/TypewriterSwiftExampleTests.swift delete mode 100644 tests/e2e/ios-swift/typewriter.yml delete mode 100644 tests/e2e/node-javascript/analytics/index.js delete mode 100644 tests/e2e/node-javascript/analytics/plan.json delete mode 100644 tests/e2e/node-javascript/index.js delete mode 100644 tests/e2e/node-javascript/package.json delete mode 100644 tests/e2e/node-javascript/typewriter.yml delete mode 100644 tests/e2e/node-javascript/yarn.lock delete mode 100644 tests/e2e/node-typescript/analytics/index.ts delete mode 100644 tests/e2e/node-typescript/analytics/plan.json delete mode 100644 tests/e2e/node-typescript/analytics/segment.ts delete mode 100644 tests/e2e/node-typescript/index.ts delete mode 100644 tests/e2e/node-typescript/package.json delete mode 100644 tests/e2e/node-typescript/typewriter.yml delete mode 100644 tests/e2e/node-typescript/yarn.lock delete mode 100644 tests/e2e/suite.test.ts delete mode 100644 tests/e2e/web-javascript/analytics/index.js delete mode 100644 tests/e2e/web-javascript/analytics/plan.json delete mode 100644 tests/e2e/web-javascript/cypress.json delete mode 100644 tests/e2e/web-javascript/cypress/integration/suite.js delete mode 100644 tests/e2e/web-javascript/package.json delete mode 100644 tests/e2e/web-javascript/pages/_document.jsx delete mode 100644 tests/e2e/web-javascript/pages/index.jsx delete mode 100644 tests/e2e/web-javascript/typewriter.yml delete mode 100644 tests/e2e/web-javascript/yarn.lock delete mode 100644 tests/e2e/web-typescript/analytics/index.ts delete mode 100644 tests/e2e/web-typescript/analytics/plan.json delete mode 100644 tests/e2e/web-typescript/analytics/segment.ts delete mode 100644 tests/e2e/web-typescript/cypress.json delete mode 100644 tests/e2e/web-typescript/cypress/integration/suite.js delete mode 100644 tests/e2e/web-typescript/declarations.d.ts delete mode 100644 tests/e2e/web-typescript/next.config.js delete mode 100644 tests/e2e/web-typescript/package.json delete mode 100644 tests/e2e/web-typescript/pages/_document.tsx delete mode 100644 tests/e2e/web-typescript/pages/index.tsx delete mode 100644 tests/e2e/web-typescript/tsconfig.json delete mode 100644 tests/e2e/web-typescript/typewriter.yml delete mode 100644 tests/e2e/web-typescript/yarn.lock delete mode 100644 tests/fixtures/asts.ts delete mode 100644 tests/fixtures/schemas/basicTypes.json delete mode 100644 tests/fixtures/schemas/enums.json delete mode 100644 tests/fixtures/schemas/nested.json delete mode 100644 tests/fixtures/schemas/nulls.json delete mode 100644 tests/fixtures/schemas/required.json delete mode 100644 tests/fixtures/schemas/unions.json delete mode 100644 tests/namer.test.ts diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md new file mode 100644 index 00000000..275c4355 --- /dev/null +++ b/CONTRIBUTING.md @@ -0,0 +1,291 @@ +# Thanks for taking the time to contribute to Typewriter! + +This doc provides a walkthrough of developing on, and contributing to, Typewriter. + +Please see our [issue template](ISSUE_TEMPLATE.md) for issues specifically. + +## Issues, Bugfixes and New Language Support + +Have an idea for improving Typewriter? [Submit an issue first](https://github.com/segmentio/typewriter/issues/new), and we'll be happy to help you scope it out and make sure it is a good fit for Typewriter. + +## Developing on Typewriter + +Typewriter is written using [OCLIF](https://oclif.io). + +### Build and run locally + +```sh +# Install dependencies +$ yarn +# Test your Typewriter installation by regenerating Typewriter's typewriter client. +$ yarn build +# Develop and test using OCLIFs dev runner to test any of your changes without transpiling +$ ./bin/dev build -m prod -u +``` + +### Running Tests + +```sh +$ yarn test +``` + +### Deploying + +You can deploy a new version to [`npm`](https://www.npmjs.com/package/typewriter) by running: + +``` +$ yarn release +``` + +### Adding a New Language Target + +> Before working towards adding a new language target, please [open an issue on GitHub](https://github.com/segmentio/typewriter/issues/new) that walks through your proposal for the new language support. See the [issue template](ISSUE_TEMPLATE.md) for details. + +All languages are just objects that implement the [`LanguageGenerator`](src/languages/types.ts) interface. We have a [quick an easy way](#using-quicktype) to use [Handlebars](http://handlebarsjs.com/) and [Quicktype](quicktype.io) which should cover most of the scenarios but you can always write your own [renderer](#using-a-custom-renderer). + +#### Using QuickType + +We have to start by creating the Quicktype required classes: a `Renderer` and a `TargetLanguage` + +We will start with the renderer. The `Renderer` is the class in Quicktype that outputs text to the files. We can customize the quicktype output here, and if you need to do more complex outputs you can check [Customize Quicktype Output](#customizing-quicktypes-output). For now we will stick to the basics and use the default handlebars renderer. Most scenarios will only need this. + +To create a renderer extend the appropiate renderer class of your Language. For Swift for example that is `SwiftRenderer`. We will add a `constructor` with some custom parameters we need and override a few functions. This is pretty much boilerplate code: + +```ts +import { + Name, + RenderContext, + SwiftRenderer, + SwiftTargetLanguage, + TargetLanguage, + Type, +} from 'quicktype-core'; +import { OptionValues } from 'quicktype-core/dist/RendererOptions'; +import { camelCase } from 'quicktype-core/dist/support/Strings'; +import { emitMultiline, executeRenderPlan, makeNameForTopLevelWithPrefixAndSuffix } from './quicktype-utils'; + +// We extend the Quicktype renderer for the language we will output, SwiftRenderer here for Swift +class TypewriterSwiftRenderer extends SwiftRenderer { + // Implement our own constructor to add our typewriterOptions + constructor( + targetLanguage: TargetLanguage, + renderContext: RenderContext, + typescriptOptions: OptionValues, + protected readonly typewriterOptions: QuicktypeTypewriterSettings, + ) { + super(targetLanguage, renderContext, typescriptOptions); + } + + // Override emitMultiline, this way you can customize the indentation size of your template files + emitMultiline(linesString: string) { + emitMultiline(this, linesString, 4); // Replace 4 with your indentation size + } + + // Override emitSource, this is the function that actually outputs code to the files. If you need to customize or prefer to output stuff through Quicktype this is the place! + emitSource(givenOutputFilename: string): void { + super.emitSource(givenOutputFilename); + // executeRenderPlan will render code from the handlebars templates, + executeRenderPlan(this, this.typewriterOptions.generators); + } + + // Override makeNameForTopLevel, this is the function that defines the names for our top level classes, the events in our case. We add custom prefixes and suffixes support through this! + makeNameForTopLevel(t: Type, givenName: string, maybeNamedType: Type | undefined): Name { + return makeNameForTopLevelWithPrefixAndSuffix( + // This is important, we do this to bind `this` as the internal Quicktype implementation relies on it + (...args) => { + return super.makeNameForTopLevel(...args); + }, + this.typewriterOptions, + t, + givenName, + maybeNamedType, + ); + } +} +``` + +Now it's time to create our own `TargetLanguage`. Again this is just boilerplate, we will just extend the appropiate Quicktype language class and make it use our own renderer: + +```ts +// We extend the TargetLanguage class for the language we will output, here for Swift +class TypewriterSwiftLanguage extends SwiftTargetLanguage { + // override the constructor to receive our typewriter options + constructor(protected readonly typewriterOptions: QuicktypeTypewriterSettings) { + super(); + } + + // override the makeRenderer to use the Renderer class we defined before + protected makeRenderer( + renderContext: RenderContext, + untypedOptionValues: { [name: string]: any }, + ): TypewriterSwiftRenderer { + return new TypewriterSwiftRenderer( + this, + renderContext, + // This part is somewhat tricky, `swiftOptions` is an object defined quicktype-core each languague has its own object, it is a good idea to take a peek at quicktype to figure out what's its name. f.e. https://github.com/quicktype/quicktype/blob/b481ea541c93b7e3ca01aaa65d4ec72492fdf699/src/quicktype-core/language/Swift.ts#L48 + getOptionValues(swiftOptions, untypedOptionValues), + this.typewriterOptions, + ); + } +} +``` + +We are done with Quicktype's boilerplate code. Let's get to our actual implementation. We will start by creating our code template. This is a Handlebars file inside `languages/templates` to which we pass in several variables: + +- `version` -> Typewriter Version number +- `type` -> array of all the types generated for the tracking plan + - `functionName` -> the type's function name + - `eventName` -> event name + - `typeName` -> event's generated type name + +A simple template will look like this, iterating over all the types and outputing the functions for each one of them: + +```hbs +import Segment + +extension Analytics { + {{#type}} + func {{functionName}}(properties: {{typeName}}) { + self.track(event: "{{eventName}}", properties: properties) + } + {{/type}} +} +``` + +Time to wrap it up, as we mentioned each language generator just needs to implement [`LanguageGenerator`](src/languages/types.ts) as we mentioned, but you don't have to manually implement the properties with quicktype. We can use [`createQuicktypeLanguageGenerator`](src/languages/quicktype-utils.ts) to create a generator for us with all the pieces: + +```ts +export const swift = createQuicktypeLanguageGenerator({ + name: 'swift', + // We pass in the class we created before for our language + quicktypeLanguage: TypewriterSwiftLanguage, + // We define in this array the SDKs we support and where the templates for each one are located + supportedSDKs: [ + { + name: 'Analytics.Swift', + id: 'swift', + templatePath: 'templates/swift/analytics.hbs', + }, + // You can also define an empty SDK for generating types without additional code + { + name: 'None (Types and validation only)', + id: 'none', + }, + ], + // We pass in any default values for the options + defaultOptions: { + 'just-types': true, + }, + // You can also add unsupported options for quicktype, that way they won't show up during configuration nor let the user set them in the config file + unsupportedOptions: ['framework'], + // Customize here how your functionNames and typeNames should look like, + nameModifiers: { + functionName: camelCase, + } +}); +``` + +Finally let's add the language to the supported languages so that it shows up during the config wizard and it gets generated during build: add your exported language to the package exports `src/languages/index.ts`: + +```ts +export { swift } from './swift'; +``` + +In `src/hooks/prerun/load-languages.ts` add this instance: + +```ts +import { Hook } from '@oclif/core'; +import { kotlin, supportedLanguages, swift, typescript } from '../../languages'; + +const hook: Hook<'init'> = async function (opts) { + // We inject any new languages plugins might support here + supportedLanguages.push(swift, kotlin, typescript); +}; + +export default hook; +``` + +##### Customizing Quicktype's output + +If you need to do something more specific with Quicktype's rendering the `Renderer` is the right place to start. For example if we want to specify exactly the order of the emitted output we can override the `emitSourceStructure`, most of this code is taken verbatim from `TypescriptRenderer` but we add the `emitAnalytics` there to inject our analytics stuff: + +```ts + protected emitSourceStructure() { + if (this.leadingComments !== undefined) { + this.emitCommentLines(this.leadingComments); + } else { + this.emitUsageComments(); + } + this.emitTypes(); + this.emitConvertModule(); + this.emitConvertModuleHelpers(); + executeRenderPlan(this, this.typewriterOptions.generators, { + functionName: camelCase, + typeName: pascalCase, + }); + this.emitModuleExports(); + } +``` + +In `Quicktype` each `Renderer` might have custom functions to emit parts of the generated types. It is always a good idea to take a peek at the available methods in the class you're extending. + +`ConvenienceRenderer` is a superclass that all renderers inherit and has most of the basic functionality you will need. Some pretty handy functions are: + +- `emitMultiline`: outputs a code block with the right indentation +- `emitLine`: will output a single line to the file +- `forEachTopLevel` iterates over each of the top level types +- `changeIndent` to modify indentation levels +- `ensureBlankLine` to add empty lines +- `emitLineOnce` ensures that a line is only output once at most per file. This is very handy for imports. + +If you want to dive deeper into the quicktype renderers, Quicktype has a [good guide](https://blog.quicktype.io/customizing-quicktype/) on how to extend them. + +It's also handy to peek at the Quicktype code files for more ideas: + +- [ConvenienceRenderer](https://github.com/quicktype/quicktype/blob/master/src/quicktype-core/ConvenienceRenderer.ts) +- [Renderer](https://github.com/quicktype/quicktype/blob/master/src/quicktype-core/ConvenienceRenderer.ts) +- [SwiftRenderer](https://github.com/quicktype/quicktype/blob/master/src/quicktype-core/language/Swift.ts) +- [TypescriptRenderer](https://github.com/quicktype/quicktype/blob/2543fa55d0d3208bbb0feb8377cecee69e721caa/src/quicktype-core/language/TypeScriptFlow.ts) + +#### Using a custom renderer + +If your use case is complex or QuickType doesn't support your language you can create your own language from scratch. You only need to implement the interface for `LanguageGenerator`: + +```ts +export interface LanguageGenerator { + /** + * Language ID + */ + id: string; + /** + * Language User-Friendly Name + */ + name: string; + /** + * File extension + */ + extension: string; + /** + * Options for the language generation. + * They are passed in an inquirer.js (https://github.com/SBoudrias/Inquirer.js) friendly version to be asked during configuration + */ + options?: QuestionCollection; + /** + * Key-value pairs of supported SDKs by the language generator. + * Key is the user friendly string + * Value is used in the configuration + */ + supportedSDKs: { + [key: string]: string; + }; + /** + * Generates code from a set of Segment Protocol Rules + * @param rules Segment PublicAPI rules object + * @param options header, sdk and additional renderer options (optional) + * @returns generated code as string + */ + generate: (rules: SegmentAPI.RuleMetadata[], options: GeneratorOptions) => Promise; +} +``` + +A good example is the [`javascript`](src/languages/javascript.ts) generator, which just wraps the typescript generator and compiles to TS according to its own custom options. diff --git a/LICENSE b/LICENSE new file mode 100644 index 00000000..9c3721a6 --- /dev/null +++ b/LICENSE @@ -0,0 +1,21 @@ +MIT License + +Copyright (c) 2019 Segment + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/Makefile b/Makefile deleted file mode 100644 index fd7981e1..00000000 --- a/Makefile +++ /dev/null @@ -1,278 +0,0 @@ -DESTINATION ?= "platform=iOS Simulator,name=iPhone 11" -XC_OBJECTIVE_C_ARGS := -workspace TypewriterExample.xcworkspace -scheme TypewriterExample -destination $(DESTINATION) -XC_SWIFT_ARGS := -workspace TypewriterSwiftExample.xcworkspace -scheme TypewriterSwiftExample -destination $(DESTINATION) - -.PHONY: update build prod bulk -build: COMMAND=build -build: bulk -prod: COMMAND=prod -prod: bulk -update: COMMAND=update -update: bulk -bulk: - @echo " >> Building typewriter" - @yarn build - @echo " >> Running 'typewriter $(COMMAND)' on 'typewriter'" - @NODE_ENV=development node ./dist/src/cli/index.js $(COMMAND) - @echo " >> Running 'typewriter $(COMMAND)' on 'example'" - @NODE_ENV=development node ./dist/src/cli/index.js $(COMMAND) --config=example - @echo " >> Running 'typewriter $(COMMAND)' on 'tests/e2e/node-javascript'" - @NODE_ENV=development node ./dist/src/cli/index.js $(COMMAND) --config=tests/e2e/node-javascript - @echo " >> Running 'typewriter $(COMMAND)' on 'tests/e2e/node-typescript'" - @NODE_ENV=development node ./dist/src/cli/index.js $(COMMAND) --config=tests/e2e/node-typescript - @echo " >> Running 'typewriter $(COMMAND)' on 'tests/e2e/web-javascript'" - @NODE_ENV=development node ./dist/src/cli/index.js $(COMMAND) --config=tests/e2e/web-javascript - @echo " >> Running 'typewriter $(COMMAND)' on 'tests/e2e/web-typescript'" - @NODE_ENV=development node ./dist/src/cli/index.js $(COMMAND) --config=tests/e2e/web-typescript - @echo " >> Running 'typewriter $(COMMAND)' on 'tests/e2e/ios-objc'" - @NODE_ENV=development node ./dist/src/cli/index.js $(COMMAND) --config=tests/e2e/ios-objc - @echo " >> Running 'typewriter $(COMMAND)' on 'tests/e2e/ios-swift'" - @NODE_ENV=development node ./dist/src/cli/index.js $(COMMAND) --config=tests/e2e/ios-swift - @echo " >> Running 'typewriter $(COMMAND)' on 'tests/e2e/android-java'" - @NODE_ENV=development node ./dist/src/cli/index.js $(COMMAND) --config=tests/e2e/android-java - @# Changes to the Tracking Plan JSON files will need to be run through our - @# linter again to reduce git deltas. - @make lint - -# e2e: launches our end-to-end test for each client library. -.PHONY: e2e -e2e: - @### Boot the sidecar API to capture API requests. - @make docker - - @### Example App - @make build-example - - @### JavaScript node - @make test-node-javascript - @### TypeScript node - @make test-node-typescript - - @### JavaScript web - @make test-web-javascript - @### TypeScript web - @make test-web-typescript - - @### Objective-C iOS - @make test-ios-objc - @### Swift iOS - @make test-ios-swift - - @### Android - @make test-android-java - -.PHONY: lint -lint: - @yarn run eslint --fix 'src/**/*.ts' 'src/**/*.tsx' - @yarn run -s prettier --write --loglevel warn '**/*.json' '**/*.yml' - -# docker: launches segmentio/mock which we use to mock the Segment API for e2e testing. -.PHONY: docker -docker: - @docker-compose -f tests/e2e/docker-compose.yml up -d - @while [ "`docker inspect -f {{.State.Health.Status}} e2e_mock_1`" != "healthy" ]; do sleep 1; done - @make clear-mock - -# clear-mock: Clears segmentio/mock to give an e2e test a clean slate. -.PHONY: clear-mock -clear-mock: - @curl -f "http://localhost:8765/messages" > /dev/null 2>&1 || (echo "Failed to clear segmentio/mock. Is it running? Try 'make docker'"; exit 1) - -# teardown: shuts down the sidecar. -.PHONY: teardown -teardown: - @docker-compose -f tests/e2e/docker-compose.yml down - -.PHONY: build-example -build-example: - @yarn run -s dev build --config=./example && \ - cd example && \ - yarn && \ - yarn build - -.PHONY: test-node-javascript -test-node-javascript: test-node-javascript-dev test-node-javascript-prod - -.PHONY: test-node-javascript-dev -test-node-javascript-dev: - @echo "\n>>> 🏃 Running dev JavaScript Node client test suite...\n" - @make clear-mock && \ - yarn run -s dev build --config=./tests/e2e/node-javascript && \ - cd tests/e2e/node-javascript && \ - yarn && \ - NODE_ENV=test yarn run -s test && \ - cd ../../.. && \ - SDK=analytics-node LANGUAGE=javascript IS_DEVELOPMENT=true yarn run -s jest ./tests/e2e/suite.test.ts - -.PHONY: test-node-javascript-prod -test-node-javascript-prod: - @echo "\n>>> 🏃 Running prod JavaScript Node client test suite...\n" - @make clear-mock && \ - yarn run -s dev prod --config=./tests/e2e/node-javascript && \ - cd tests/e2e/node-javascript && \ - yarn && \ - NODE_ENV=test yarn run -s test && \ - cd ../../.. && \ - SDK=analytics-node LANGUAGE=javascript IS_DEVELOPMENT=false yarn run -s jest ./tests/e2e/suite.test.ts - -.PHONY: test-node-typescript -test-node-typescript: test-node-typescript-dev test-node-typescript-prod - -.PHONY: test-node-typescript-dev -test-node-typescript-dev: - @echo "\n>>> 🏃 Running dev TypeScript Node client test suite...\n" - @make clear-mock && \ - yarn run -s dev build --config=./tests/e2e/node-typescript && \ - cd tests/e2e/node-typescript && \ - yarn && \ - NODE_ENV=test yarn run -s test && \ - cd ../../.. && \ - SDK=analytics-node LANGUAGE=typescript IS_DEVELOPMENT=true yarn run -s jest ./tests/e2e/suite.test.ts - -.PHONY: test-node-typescript-prod -test-node-typescript-prod: - @echo "\n>>> 🏃 Running prod TypeScript Node client test suite...\n" - @make clear-mock && \ - yarn run -s dev prod --config=./tests/e2e/node-typescript && \ - cd tests/e2e/node-typescript && \ - yarn && \ - yarn run -s test && \ - cd ../../.. && \ - SDK=analytics-node LANGUAGE=typescript IS_DEVELOPMENT=false yarn run -s jest ./tests/e2e/suite.test.ts - -.PHONY: test-web-javascript -test-web-javascript: test-web-javascript-dev test-web-javascript-prod - -.PHONY: test-web-javascript-dev -test-web-javascript-dev: - @echo "\n>>> 🏃 Running dev JavaScript analytics.js client test suite...\n" - @make clear-mock && \ - yarn run -s dev build --config=./tests/e2e/web-javascript && \ - cd tests/e2e/web-javascript && \ - yarn && \ - yarn run -s build && \ - NODE_ENV=test yarn run -s test && \ - cd ../../.. && \ - SDK=analytics.js LANGUAGE=javascript IS_DEVELOPMENT=true yarn run -s jest ./tests/e2e/suite.test.ts - -.PHONY: test-web-javascript-prod -test-web-javascript-prod: - @echo "\n>>> 🏃 Running prod JavaScript analytics.js client test suite...\n" - @make clear-mock && \ - yarn run -s dev prod --config=./tests/e2e/web-javascript && \ - cd tests/e2e/web-javascript && \ - yarn && \ - yarn run -s build && \ - yarn run -s test && \ - cd ../../.. && \ - SDK=analytics.js LANGUAGE=javascript IS_DEVELOPMENT=false yarn run -s jest ./tests/e2e/suite.test.ts - -.PHONY: test-web-typescript -test-web-typescript: test-web-typescript-dev test-web-typescript-prod - -.PHONY: test-web-typescript-dev -test-web-typescript-dev: - @echo "\n>>> 🏃 Running dev TypeScript analytics.js client test suite...\n" - @make clear-mock && \ - yarn run -s dev build --config=./tests/e2e/web-typescript && \ - cd tests/e2e/web-typescript && \ - yarn && \ - yarn run -s build && \ - NODE_ENV=test yarn run -s test && \ - cd ../../.. && \ - SDK=analytics.js LANGUAGE=typescript IS_DEVELOPMENT=true yarn run -s jest ./tests/e2e/suite.test.ts - -.PHONY: test-web-typescript-prod -test-web-typescript-prod: - @echo "\n>>> 🏃 Running prod TypeScript analytics.js client test suite...\n" - @make clear-mock && \ - yarn run -s dev prod --config=./tests/e2e/web-typescript && \ - cd tests/e2e/web-typescript && \ - yarn && \ - yarn run -s build && \ - yarn run -s test && \ - cd ../../.. && \ - SDK=analytics.js LANGUAGE=typescript IS_DEVELOPMENT=false yarn run -s jest ./tests/e2e/suite.test.ts - -.PHONY: test-ios-objc -test-ios-objc: - @# TODO: verify that xcodebuild and xcpretty are available - @cd tests/e2e/ios-objc && pod install - @make test-ios-objc-dev test-ios-objc-prod - -.PHONY: test-ios-swift -test-ios-swift: - @# TODO: verify that xcodebuild and xcpretty are available - @cd tests/e2e/ios-swift && pod install - @make test-ios-swift-dev test-ios-swift-prod - -.PHONY: test-android-java -test-android-java: - @cd tests/e2e/android-java - @make test-android-java-dev test-android-java-prod - -.PHONY: test-android-java-dev test-android-java-prod test-android-java-runner test-android-java-runner -test-android-java-dev: IS_DEVELOPMENT=true -test-android-java-dev: TYPEWRITER_COMMAND=build -test-android-java-dev: test-android-java-runner - -test-android-java-prod: IS_DEVELOPMENT=false -test-android-java-prod: TYPEWRITER_COMMAND=prod -test-android-java-prod: test-android-java-runner - -test-android-java-runner: LANGUAGE=java -test-android-java-runner: - @echo "\n>>> 🏃 Running Android client test suite ($(TYPEWRITER_COMMAND), $(LANGUAGE))...\n" - @make clear-mock - @yarn run -s dev $(TYPEWRITER_COMMAND) --config=./tests/e2e/android-java - @cd tests/e2e/android-java && ./gradlew --rerun-tasks testDebugUnitTest - @SDK=analytics-android LANGUAGE=$(LANGUAGE) IS_DEVELOPMENT=$(IS_DEVELOPMENT) yarn run -s jest ./tests/e2e/suite.test.ts - -.PHONY: test-ios-objc-dev test-ios-objc-prod test-ios-objc-runner test-ios-swift-dev test-ios-swift-prod test-ios-swift-runner test-ios-runner -test-ios-objc-dev: IS_DEVELOPMENT=true -test-ios-objc-dev: TYPEWRITER_COMMAND=build -test-ios-objc-dev: test-ios-objc-runner - -test-ios-objc-prod: IS_DEVELOPMENT=false -test-ios-objc-prod: TYPEWRITER_COMMAND=prod -test-ios-objc-prod: test-ios-objc-runner - -test-ios-objc-runner: LANGUAGE=objc -test-ios-objc-runner: XC_ARGS=$(XC_OBJECTIVE_C_ARGS) -test-ios-objc-runner: test-ios-runner - -test-ios-swift-dev: IS_DEVELOPMENT=true -test-ios-swift-dev: TYPEWRITER_COMMAND=build -test-ios-swift-dev: test-ios-swift-runner - -test-ios-swift-prod: IS_DEVELOPMENT=false -test-ios-swift-prod: TYPEWRITER_COMMAND=prod -test-ios-swift-prod: test-ios-swift-runner - -test-ios-swift-runner: LANGUAGE=swift -test-ios-swift-runner: XC_ARGS=$(XC_SWIFT_ARGS) -test-ios-swift-runner: test-ios-runner - -test-ios-runner: - @echo "\n>>> 🏃 Running iOS client test suite ($(TYPEWRITER_COMMAND), $(LANGUAGE))...\n" - @make clear-mock - @yarn run -s dev $(TYPEWRITER_COMMAND) --config=./tests/e2e/ios-$(LANGUAGE) - @cd tests/e2e/ios-$(LANGUAGE) && set -o pipefail && xcodebuild test $(XC_ARGS) | xcpretty - @SDK=analytics-ios LANGUAGE=$(LANGUAGE) IS_DEVELOPMENT=$(IS_DEVELOPMENT) yarn run -s jest ./tests/e2e/suite.test.ts - -.PHONY: precommit -precommit: - @make build - - @# Lint the working directory: - @yarn run lint-staged - -.PHONY: update-bridging-header -update-bridging-header: - @echo "// Generated Typewriter Headers:" > \ - tests/e2e/ios-swift/TypewriterSwiftExample/TypewriterSwiftExample-Bridging-Header.h - @ls -l tests/e2e/ios-swift/TypewriterSwiftExample/Analytics | \ - grep '.h$$' | \ - sed -e 's/^.*SEG/#import "Analytics\/SEG/' | \ - sed -e 's/$$/"/' >> \ - tests/e2e/ios-swift/TypewriterSwiftExample/TypewriterSwiftExample-Bridging-Header.h diff --git a/README.md b/README.md index 0a1696f1..7a42b857 100644 --- a/README.md +++ b/README.md @@ -47,3 +47,16 @@ For more instructions on setting up your `typewriter` client, such as adding it - To submit a bug report or feature request, [file an issue here](issues). - To develop on `typewriter` or propose support for a new language, see [our contributors documentation](./.github/CONTRIBUTING.md). + + +## Migrating from v7 + +Check the instructions on our [documentation](https://segment.com/docs/protocols/typewriter) + +- You'll need to change your Segment Config API Token for a Public API Token +- v8 doesn't support **Analytics-iOS** nor **Analytics-Android**. We recommend using [Analytics-Swift]() and [Analytics-Kotlin]() instead which are supported. +If you need to use these libraries you can run v7 specifying the version with your commands: + +```sh +$ npx typewriter@7 build +``` \ No newline at end of file diff --git a/bin/dev b/bin/dev new file mode 100755 index 00000000..0929bd13 --- /dev/null +++ b/bin/dev @@ -0,0 +1,18 @@ +#!/usr/bin/env node + +const oclif = require('@oclif/core') + +const path = require('path') +const project = path.join(__dirname, '..', 'tsconfig.json') + +// In dev mode -> use ts-node and dev plugins +process.env.NODE_ENV = 'development' + +require('ts-node').register({project}) + +// In dev mode, always show stack traces +oclif.settings.debug = true; +oclif.settings.tsnodeEnabled = true; + +// Start the CLI +oclif.run().then(oclif.flush).catch(oclif.Errors.handle) diff --git a/bin/dev.cmd b/bin/dev.cmd new file mode 100644 index 00000000..077b57ae --- /dev/null +++ b/bin/dev.cmd @@ -0,0 +1,3 @@ +@echo off + +node "%~dp0\dev" %* \ No newline at end of file diff --git a/bin/run b/bin/run new file mode 100755 index 00000000..a7635de8 --- /dev/null +++ b/bin/run @@ -0,0 +1,5 @@ +#!/usr/bin/env node + +const oclif = require('@oclif/core') + +oclif.run().then(require('@oclif/core/flush')).catch(require('@oclif/core/handle')) diff --git a/bin/run.cmd b/bin/run.cmd new file mode 100644 index 00000000..968fc307 --- /dev/null +++ b/bin/run.cmd @@ -0,0 +1,3 @@ +@echo off + +node "%~dp0\run" %* diff --git a/example/README.md b/example/README.md deleted file mode 100644 index 25e9b5c8..00000000 --- a/example/README.md +++ /dev/null @@ -1,44 +0,0 @@ -# Typewriter Example - -This example repo demonstrates how to setup and use Typewriter in a JavaScript/TypeScript web environment, as a strongly-typed wrapper for [`analytics.js`](https://segment.com/docs/sources/website/analytics.js/). - -## Setup - -First, install dependencies: - -```sh -$ yarn -``` - -Then, generate a Typewriter client: - -```sh -$ yarn typewriter dev -``` - -Update the Segment write key in [`_document.tsx`](./pages/_document.tsx#L48) for the source you want to report analytics to: - -```typescript -const analyticsSnippet = snippetFn({ - apiKey: '', - page: false, -}) -``` - -Run the development server: - -```sh -$ yarn run dev -DONE Compiled successfully in 1409ms 18:15:03 - -> Ready on http://localhost:3000 -No type errors found -Version: typescript 3.1.1 -Time: 2219ms -``` - -Once you run the app, go the Debugger to see events coming in! - -## More Documentation - -See the [`Typewriter docs`](https://segment.com/docs/protocols/typewriter) for more information on instrumenting your app with Typewriter. diff --git a/example/analytics/plan.json b/example/analytics/plan.json deleted file mode 100644 index 952fe972..00000000 --- a/example/analytics/plan.json +++ /dev/null @@ -1,149 +0,0 @@ -{ - "create_time": "2019-10-21T17:15:38.000Z", - "display_name": "Typewriter Example Tracking Plan", - "name": "workspaces/segment_prod/tracking-plans/rs_1SWT1hC4xpwcltyCUud43XMIlQo", - "rules": { - "events": [ - { - "description": "Fired after a user's signin attempt fails to pass validation.", - "name": "Sign In Failed", - "rules": { - "$schema": "http://json-schema.org/draft-07/schema#", - "labels": {}, - "properties": { - "context": {}, - "properties": { - "properties": { - "id": { - "description": "The user's ID.", - "type": "string" - }, - "numAttempts": { - "description": "How many times the user has attempted to sign-in.", - "type": "integer" - }, - "rememberMe": { - "description": "Whether the user has indicated that the browser should store their login credentials.", - "type": "boolean" - } - }, - "required": ["id"], - "type": "object" - }, - "traits": { - "type": "object" - } - }, - "required": ["properties"], - "type": "object" - }, - "version": 1 - }, - { - "description": "Fired when a user submits a sign in, prior to validating that user's login.", - "name": "Sign In Submitted", - "rules": { - "$schema": "http://json-schema.org/draft-07/schema#", - "labels": {}, - "properties": { - "context": {}, - "properties": { - "properties": { - "id": { - "description": "The user's ID.", - "type": "string" - }, - "numAttempts": { - "description": "How many times the user has attempted to sign-in.", - "type": "integer" - }, - "rememberMe": { - "description": "Whether the user has indicated that the browser should store their login credentials.", - "type": "boolean" - } - }, - "required": ["id"], - "type": "object" - }, - "traits": { - "type": "object" - } - }, - "type": "object" - }, - "version": 1 - }, - { - "description": "Fired when a user successfully submits a sign in, prior to redirecting into the app.", - "name": "Sign In Succeeded", - "rules": { - "$schema": "http://json-schema.org/draft-07/schema#", - "labels": {}, - "properties": { - "context": {}, - "properties": { - "properties": { - "id": { - "description": "The user's ID.", - "type": "string" - }, - "numAttempts": { - "description": "How many times the user has attempted to sign-in.", - "type": "integer" - }, - "rememberMe": { - "description": "Whether the user has indicated that the browser should store their login credentials.", - "type": "boolean" - } - }, - "required": ["id"], - "type": "object" - }, - "traits": { - "type": "object" - } - }, - "type": "object" - }, - "version": 1 - }, - { - "description": "Fired when a user successfully submits a sign in, prior to redirecting into the app.", - "name": "User Signed Out", - "rules": { - "$schema": "http://json-schema.org/draft-07/schema#", - "labels": {}, - "properties": { - "context": {}, - "properties": { - "properties": { - "id": { - "description": "The user's ID.", - "type": "string" - }, - "numAttempts": { - "description": "How many times the user has attempted to sign-in.", - "type": "integer" - }, - "rememberMe": { - "description": "Whether the user has indicated that the browser should store their login credentials.", - "type": "boolean" - } - }, - "required": ["id"], - "type": "object" - }, - "traits": { - "type": "object" - } - }, - "type": "object" - }, - "version": 1 - } - ], - "group_traits": [], - "identify_traits": [] - }, - "update_time": "2020-03-04T18:20:43.000Z" -} diff --git a/example/components/Home.tsx b/example/components/Home.tsx deleted file mode 100644 index a5b1f7ad..00000000 --- a/example/components/Home.tsx +++ /dev/null @@ -1,59 +0,0 @@ -import React from 'react' -import { Pane, Button, majorScale, Card, Paragraph, Text, Link } from 'evergreen-ui' -import Router, { withRouter } from 'next/router' -import { get } from 'lodash' - -type Props = { - onSignOut: (props: { id: string }) => void -} - -class HomeComponent extends React.Component { - private onSignOut = () => { - const id = get(this.props, 'router.query.id') - - this.props.onSignOut({ - id, - }) - - Router.push('/login') - } - - public render() { - return ( - - - - - - - - - Getting started with Typewriter is as simple as: -
npx typewriter@next init
-
-
- - - You can learn more from our documentation: {''} - - https://segment.com/docs/protocols/typewriter - - - -
-
-
- ) - } -} - -// HOCs are a pain. any = temporary fix. -export const Home: React.FC = withRouter(HomeComponent as any) as any diff --git a/example/components/LoginForm.tsx b/example/components/LoginForm.tsx deleted file mode 100644 index ad96cf3a..00000000 --- a/example/components/LoginForm.tsx +++ /dev/null @@ -1,197 +0,0 @@ -import * as React from 'react' -import { - Pane, - Button, - Text, - TextInput, - Heading, - Card, - Checkbox, - toaster, - Paragraph, - Link, - majorScale, -} from 'evergreen-ui' -import Router from 'next/router' - -interface Props { - onSubmit: (props: { id: string; numAttempts: number; rememberMe: boolean }) => void - onSuccess: (props: { id: string; numAttempts: number; rememberMe: boolean }) => void - onError: (props: { id: string; numAttempts: number; rememberMe: boolean }) => void -} - -interface State { - id: string - password: string - rememberMe: boolean - isLoading: boolean - success: boolean - numAttempts: number -} - -export class LoginForm extends React.Component { - public state = { - id: '', - password: '', - rememberMe: true, - isLoading: false, - success: false, - numAttempts: 0, - } - - // Much secret. Many legit. 🐕 - private superSecretEncryptedUserStore: Record = { - // The Protocols EPD Squad 🙌 - andy: 'password', - archana: 'password', - caledona: 'password', - catherine: 'password', - colin: 'password', - daniel: 'password', - frances: 'password', - francisco: 'password', - gurdas: 'password', - hareem: 'password', - heidi: 'password', - kat: 'password', - niels: 'password', - pengcheng: 'password', - } - - private onChangeUserId = (event: React.ChangeEvent) => { - this.setState({ - id: event.target.value, - }) - } - - private onChangePassword = (event: React.ChangeEvent) => { - this.setState({ - password: event.target.value, - }) - } - - private onToggleRememberMe = (event: React.ChangeEvent) => { - this.setState({ - rememberMe: event.target.checked, - }) - } - - private onSubmit = () => { - this.setState( - prev => { - return { - isLoading: true, - numAttempts: prev.numAttempts + 1, - } - }, - () => { - this.props.onSubmit({ - id: this.state.id, - rememberMe: this.state.rememberMe, - numAttempts: this.state.numAttempts, - }) - - const fakeNetworkLatency = (Math.random() + 1) * 500 - setTimeout(() => { - if (this.superSecretEncryptedUserStore[this.state.id] !== this.state.password) { - // This isn't a valid login, show an error state. - this.setState({ - isLoading: false, - }) - - toaster.danger("Hmm. That didn't work.", { - description: 'The username or password you entered was incorrect.', - }) - - this.props.onError({ - id: this.state.id, - rememberMe: this.state.rememberMe, - numAttempts: this.state.numAttempts, - }) - } else { - // Successful login, go ahead and redirect to the user's home. - this.setState({ - success: true, - }) - - this.props.onSuccess({ - id: this.state.id, - rememberMe: this.state.rememberMe, - numAttempts: this.state.numAttempts, - }) - - Router.push(`/home?id=${this.state.id}`) - } - }, fakeNetworkLatency) - } - ) - } - - public render() { - return ( - - - - Log in to Segment - - Email * - - Password * - - - - - - Forgot your password? {''} - - Reset your password - - - - Don't have an account? {''} - - Sign up - - - - - - ) - } -} diff --git a/example/declarations.d.ts b/example/declarations.d.ts deleted file mode 100644 index 896cba79..00000000 --- a/example/declarations.d.ts +++ /dev/null @@ -1,2 +0,0 @@ -declare module 'evergreen-ui' -declare module '@segment/snippet' diff --git a/example/next-env.d.ts b/example/next-env.d.ts deleted file mode 100644 index 7b7aa2c7..00000000 --- a/example/next-env.d.ts +++ /dev/null @@ -1,2 +0,0 @@ -/// -/// diff --git a/example/package.json b/example/package.json deleted file mode 100644 index 388dfcf6..00000000 --- a/example/package.json +++ /dev/null @@ -1,43 +0,0 @@ -{ - "name": "typewriter-example", - "version": "1.0.0", - "description": "Example web app using Typewriter's TS analytics.js client", - "repository": "https://github.com/segmentio/typewriter", - "author": "Colin King ", - "license": "MIT", - "private": true, - "scripts": { - "dev": "next", - "build": "next build", - "start": "next start", - "test": "jest" - }, - "dependencies": { - "@segment/snippet": "^4.14.2", - "evergreen-ui": "^6.1.0", - "next": "^10.0.0", - "react": "^16.14.0", - "react-dom": "^16.14.0", - "request": "^2.88.0", - "typescript": "^4.3.5" - }, - "devDependencies": { - "@types/react": "^16.14.11", - "@types/segment-analytics": "^0.0.34", - "@types/styled-jsx": "^2.2.9", - "enzyme": "^3.11.0", - "enzyme-adapter-react-16": "^1.15.6", - "fork-ts-checker-webpack-plugin": "^5.2.1", - "jest": "^27.0.6", - "typewriter": "7.2.1" - }, - "resolutions": { - "lodash": ">=4.17.21", - "node-fetch": ">=2.6.1" - }, - "jest": { - "setupFilesAfterEnv": [ - "tests/setup-tests.js" - ] - } -} diff --git a/example/pages/_document.tsx b/example/pages/_document.tsx deleted file mode 100644 index 0768b73b..00000000 --- a/example/pages/_document.tsx +++ /dev/null @@ -1,69 +0,0 @@ -import React from 'react' -import Document, { - Head, - Main, - NextScript, - DocumentContext, - DocumentInitialProps, -} from 'next/document' -import { extractStyles } from 'evergreen-ui' -import * as snippet from '@segment/snippet' - -interface Props extends Document { - css: string - hydrationScript: string -} - -export default class SSRDoc extends Document { - // Inject Evergreen's styles so that Next can perform SSR with it. - public static getInitialProps({ renderPage }: DocumentContext): Promise { - const page = renderPage() - const { css, hydrationScript } = extractStyles() - - return { - ...page, - css, - hydrationScript, - } as any - } - - public render() { - const { css, hydrationScript } = this.props - - const globalStyles = ` - html { - height: '100%'; - } - body { - height: '100%'; - background: rgb(247, 248, 250); - margin: 0; - } - ` - - // Generate and inject the Segment analytics.js snippet. - const snippetFn = process.env.NODE_ENV === 'production' ? snippet.min : snippet.max - // https://app.segment.com/segment_prod/sources/typewriter-source/overview - const analyticsSnippet = snippetFn({ - apiKey: 'ZgsqNXhzqQ3nBsvPGXqZQn2RWoGBhlqC', - page: false, - }) - - return ( - - - - - - -
- {hydrationScript} - - -