Skip to content
This repository has been archived by the owner on Feb 11, 2024. It is now read-only.
/ hotspot.js Public archive

This is Back end oriented project. URL works only on Front end side unless integrated.

License

Notifications You must be signed in to change notification settings

projektorius96/hotspot.js

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

7 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

hotspot.js (+gas integration provided)

HTML5 CSS3 Javascript
GAS

Table of Content [under construction]
  1. About The Project
  2. Getting Started
  3. Prerequisites [IMPORTANT]
  4. Acknowledgements
  5. Useful references
  6. License

Cited: Apps Script is a scripting platform developed by Google for light-weight application development in the Google Workspace platform. Google Apps Script was initially developed by Mike Harm as a side project whilst working as a developer on Google Sheets.

It's over the decade to be be open for everyone who is least one hand into Google Services such as Google Docs, Maps or Sheets. Particular to later i.e. Google Sheets (GS) that comes hand in hand with Google Apps Script (GAS) Integrated Development Environment (IDE) can be made use of as for back-end projects i.e. the database on the fly with a few lines of code as presented within boilerplate in Getting Started section down below.


As GAS IDE recently switched the engine to a globally known V8, the same engine Google Chrome browser uses behind the hood as well. That's why Google Chrome would be higly recommended to use as the prerequisite environment for this back-end oriented application.


When it comes about the hotspot widget (hotspot.js) itself, all it does, it lets you place the markers on the map image by mouse clicks (more advanced GUI is one the features currently upcoming), the markers are coordinates (coords) themselves that go to Google Sheets (thanks for GAS integration provided) within every click on image map made. When you reload the browser markers will disappear in the browser DOM, but will stay in memory of Google Sheets – a primitive database replica. Introducing such widget as a part of application example into frames of the same language (in this case JavaScript within browser environment), opens doors for basic application development without PHP nor Node.js or other languages / environments / frameworks as the prerequisite needed.

For a further do I am sharing a ready to go JavaScript boilerplate for Google Apps Script (GAS) integration. This back-end boilerplate comes hand in hand with FETCH API which content declared within the file of script.js provided as an integration example with Hotspot widget written totally in vanilla JavaScript flavour by me i.e. @projektorius96 . Instead of ready deployed application I am sharing a touch of integration on one's own account of Google which is the only prerequisite needed to meet for you to be fully set.

PLEASE READ STEPS MUST FOLLOW CAREFULLY

// STEPS MUST FOLLOW:
/*
* PUBLISH THE SPREADSHEET TO ANYONE ON WEB
** DEPLOY APPS-SCRIPT's CONTENT OF : doGet, doPost TO ANYONE ON WEB
*** USE /EXEC URL (ENDPOINT) OF THE CURRENT_DEPLOYMENT_ID
*/

// BACK-END (*GOOGLE APPS-SCRIPT IDE):
  
  function doGet(e){

  try {
    const db = SpreadsheetApp.getActiveSpreadsheet().getActiveSheet(); // get active **Google Sheets | this is similar to document.getElementsById
    // const data = db.getRange("a1notation").getValues(); /* – this is an alternative accessor (reference) to range */
    const data = db.getRange(db.getLastRow(),1).getValues(); // get range of the last field (row) on **GS
    const jsonData = JSON.stringify(Object.assign({}, data.flat() )); // [[]] –> {} | /* otherwise do sth like that : JSON.stringify({accessHandler: e}); */
    Logger.log(jsonData); // to debug on *GAS IDE side
    return ContentService.createTextOutput(jsonData).setMimeType(ContentService.MimeType.JSON); // DO GET DATA to external app (localhost) if successful
  }

  catch(e){
      const error = {"error": e}; // define error object for catch{} statement
      const jsonError = JSON.stringify(error); // stringify error be ready to be passed via Network
      return ContentService.createTextOutput(jsonError).setMimeType(ContentService.MimeType.JSON); // THROW ERROR if not successful
  }
  
}

function doPost(e) {
  const body = e.postData.contents; // IN CHARGE TO ACCEPT DATA TRANSMISSION AS JSON BODY via Network
  const bodyJSON = JSON.parse(body); // Convert JSON to JavaScript object in order to understand "the content"
  const db = SpreadsheetApp.getActiveSpreadsheet().getActiveSheet(); // reference to the data on **GS
  db.getRange("A1:A20").setNumberFormat("@"); // implicitly set type format to TEXT
  db.appendRow([bodyJSON.coords]); // DO POST DATA to the **GS
  // db.appendRow([bodyJSON._sameNameHandler]); /* _sameNameHandler as within external app FETCH API POST request */
}

CAUTION : each way you follow, you will have to update request_url variable with up-to-date /CURRENT_DEPLOYMENT_ID/ of one's deployment (version) which can be found in GAS IDE Manage Deployments Dialog

For instructions on how to DEPLOY the app within GAS IDE and find DEPLOYMENT_ID for /CURRENT_DEPLOYMENT_ID/ updated onto request_url | [ read more about here ]

For GAS IDE itself, please open your container-based application file you wish (any Google Sheets file on Google Drive) and follow along the path :

Tools –> Script editor

If you want to observe all the projects of Apps Script you're on currently, you have a Dashboard for this as well [ GAS Dashboard ]


In terms of FETCH API request within script.js provided : if it appeared too advanced for one's eye, I am providing a more simplified bare minimum boilerplate . This is for Front-end particularly !

// FRONT-END:

  // Push data in Google Sheets from external app :
  const request_url = "https://script.google.com/macros/s/CURRENT_DEPLOYMENT_ID/exec";

  fetch(request_url, {
    method: 'POST',
    mode: 'no-cors',
    cache: 'no-cache',
    credentials: 'same-origin',
    headers: {
    'Content-Type': 'application/json'
    },
    redirect: 'follow',
    body: JSON.stringify(/* { _sameNameHandler: `${ Your external app dataVariable be processed via doPost(e) */)
  });

  // Pull data out (GET DATA) of Google Sheets to external app :
  fetch(request_url).then(response => response.json()).then(response => console.log(response));



About

This is Back end oriented project. URL works only on Front end side unless integrated.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published