Skip to content

Latest commit

 

History

History
53 lines (33 loc) · 2.49 KB

File metadata and controls

53 lines (33 loc) · 2.49 KB

GoodData.UI SDK - Live Examples

Getting Started

You can start the live examples locally in development mode using the npm run examples or yarn examples commands. This will start the Webpack dev server.

The application in dev mode still works on top of a live project in GoodData platform - you will need to log in using your credentials for the official live examples.

Adding new examples

All example code is located in its own directory and categorized into additional subdirectories. Inspect couple of existing example sections to get a better idea how organize examples and write example so that it includes source code.

Look for instance at chart examples or execute examples for inspiration.

To specify data to render, the examples use the LDM generated using catalog-export. This output is in the src/ldm directory together with the extensions and modifications of generated objects.

Your new examples should follow this convention. Additional practices to follow:

  • Use full capabilities of sdk-model and use factories and builders for everything

    If your example code has to fall back to working with plain objects, this is a good indication that we are missing a function in sdk-model.

  • Avoid setting custom localIds for modified objects. This is not needed in vast majority of cases. The only exception is when example needs to use the exact same measure or attribute twice (with same alias, format, definition)

    The default local id generated by calling m.defaultLocalId() during measure or attribute modification takes all properties into account and will reflect them in the ID.

  • Keep the definitions DRY

Including example code in the app itself

The app uses ExampleWithSource component to enrich your example with additional components that show JavaScript and TypeScript code behind the example:

  • Webpack raw-loader is used to include the source code

  • JavaScript example code is the TypeScript transpiled using babel. The transpilation happens at build time - which has the expected impact on dev workflow:

    • After adding a new example file, you need to rebuild the app
    • The example JavaScript code is not subject to live-update - you need to rebuild the app

License

(C) 2017-2020 GoodData Corporation

This project is under commercial license. See LICENSE.