This is a web widget to help you integrate with ACS protocol.
In order to embed the widget add the following snippet at any location on the hosting page:
<head>
  <!-- Import the styles from us or provide your own -->
  <link rel="stylesheet" href="https://d3bgshfwq8wmv6.cloudfront.net/acs-widget-staging/main.css" /> 
</head>
<body>
  ...
  <div id="acs"></div> <!-- <= Place where the ACS button will show -->
  ...
  <script>
    (function (w, d, s, o, f, js, fjs) {
        w[o] = w[o] || function () { (w[o].q = w[o].q || []).push(arguments) };
        js = d.createElement(s), fjs = d.getElementsByTagName(s)[0];
        js.id = o; js.src = f; js.async = 1; fjs.parentNode.insertBefore(js, fjs);
    }(window, document, 'script', '_acs', 'https://d3bgshfwq8wmv6.cloudfront.net/acs-widget-staging/widget.js'));
    _acs('init', {
      element: document.getElementById('acs'),
      poolId: 'Fxh4hDFHJuTfD3Eq4en36dTk8QvbsSMoTE5Y2hVX3qVt',
      poolName: "The Block",
    });
    // Here's how you listen for connected wallet and you'll receive:
    // { address: string; locked: number, airdrop: number }
    // address - user's wallet address
    // locked - amount of ACS (with decimals) locked against your pool
    // airdrop - amount of ACS (with decimals) airdroped against your pool
    // ----------------------------------------------------------------
    // NOTE: To get ACS withtout decimals divide the numbers by 10 ** 6
    document.querySelector("#acs").addEventListener("connected", (event) => {
      console.log("Connected to the wallet: " + JSON.stringify(event.detail));
    });
    document.querySelector("#acs").addEventListener("lock", (event) => {
      console.log("Connected to the wallet with address: " + JSON.stringify(event.detail));
    });
    document.querySelector("#acs").addEventListener("claim", (event) => {
      console.log("Connected to the wallet with address: " + JSON.stringify(event.detail));
    });
  </script>
</body>You can find a full list of configurations in AppConfigurations interface.
To make it work for you own pool, make sure you're change the poolId and poolName.
You can optionally change CSS class prefix classPrefix to provide your CSS styling for the app and prevent collision with your names. (By default our classPrefix is set to "acs__" which should be enough to not colide with anyone).
For production use these URLs:
- https://d3bgshfwq8wmv6.cloudfront.net/acs-widget/widget.js
- https://d3bgshfwq8wmv6.cloudfront.net/acs-widget/main.css
The widget dev setup is similar to regular client application. To get started:
yarn install
cp .env.example .env.development
vim .env.development # Fill in the right contract program ID
yarn devThis will open browser with "demo" page which hosts the widget.
git push origin main
git tag vX.X.X-beta && git push origin vX.X.X-betaAfter this wait for the Github Actions to finish the deploy to S3 and Cloudfront. The demo app will be avail at: https://d3bgshfwq8wmv6.cloudfront.net/acs-widget-staging/index.html
git push origin main
git tag vX.X.X && git push origin vX.X.XAfter this wait for the Github Actions to finish the deploy to S3 and Cloudfront. The demo app will be avail at: https://d3bgshfwq8wmv6.cloudfront.net/acs-widget/index.html
The source and documentation in this project are released under the MIT License