/budibase-archery-component-plugin

Track archery scores alone or play as a team using a custom budibase component plugin

Primary LanguageSvelte

Budibase Archery Component Plugin

Multiple Targets

Description

This component tracks archery scores as they happen.

Features:

  • Add archers to game
  • Record scores for each archer as they happen
  • Progress to next archer
  • Save the results on the game when complete

Credit for the implementation of the target component, which has been ported from react to svelte in this plugin: https://github.com/carabus/arrow-tracker

Find out more about Budibase.

Settings

  • Target Size
    • Change the size of the target (px)
  • Target Type
    • Choose between Olympic and NFAA style targets
  • Arrow Radius
    • Change the size of arrows rendered on the target (px)
  • Stroke Width
    • Change the size of lines between score boundaries on the target (px)
  • On Save Results
    • Define the action that will receive the results of the game

Handling Results

The results array has the following content

[
  {
    name: "archer1", 
    score: 21
  },
  {
    name: "archer2",
    score: 28
  }
]

This object can be referenced from an action with the following bindings:

  • Handlebars:
{{ Results }}
  • JavaScript
return $("Results")

Example: Saving to text field in Budibase DB

Configure a table as follows:

String Column Results String Table

Configure an On Save Results action as follows:

Save Results String

Example: Saving to json field in Budibase DB

JSON Column Results JSON Table

Configure an On Save Results action as follows:

Save Results JSON

With the following JavaScript function:

Save Results JSON JS

Screenshots

New Component

New Component

Add Archers

Add Archers

Game In-Progress

Game In-Progress

NFAA Target

NFAA Target

Multiple Targets

Multiple targets can be added to an app to model an archery range

Multiple Targets

Instructions

To build this plugin run the following in your Budibase CLI:

budi plugins --build

You can also re-build everytime you make a change to your plugin with the command:

budi plugins --watch