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.
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
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
(C) 2017-2020 GoodData Corporation
This project is under commercial license. See LICENSE.