-
Notifications
You must be signed in to change notification settings - Fork 162
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #806 from FabioPinheiro/Web_NFC_API
Add support for Web NFC API
- Loading branch information
Showing
10 changed files
with
374 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,22 @@ | ||
package org.scalajs.dom | ||
|
||
import scala.scalajs.js | ||
import scala.scalajs.js.annotation.JSGlobal | ||
|
||
/** The [[NDEFMessage]] interface of the Web NFC API represents the content of an NDEF message that has been read from | ||
* or could be written to an NFC tag. An instance is acquired by calling the NDEFMessage() constructor or from the | ||
* NDEFReadingEvent.message property, which is passed to the reading event. | ||
* | ||
* @see | ||
* https://w3c.github.io/web-nfc/#the-ndefmessage-interface | ||
* | ||
* @param messageInit | ||
* property of NDEFMessage interface represents a list of NDEFRecords present in the NDEF message. | ||
*/ | ||
@js.native | ||
@JSGlobal | ||
class NDEFMessage(messageInit: js.Array[NDEFRecordInit]) extends js.Object { | ||
|
||
/** Returns the list of NDEF records contained in the message. */ | ||
def records: FrozenArray[NDEFRecord] = js.native | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,63 @@ | ||
package org.scalajs.dom | ||
|
||
import scala.scalajs.js | ||
import scala.scalajs.js.annotation.JSGlobal | ||
|
||
/** The [[NDEFReader]] interface of the Web NFC API (https://developer.mozilla.org/en-US/docs/Web/API/Web_NFC_API) is | ||
* used to read from and write data to compatible NFC devices, e.g. NFC tags supporting NDEF, when these devices are | ||
* within the reader's magnetic induction field. | ||
* | ||
* @see | ||
* https://w3c.github.io/web-nfc/#the-ndefreader-object | ||
*/ | ||
@JSGlobal("NDEFReader") | ||
@js.native | ||
class NDEFReader() extends EventTarget { | ||
|
||
/** Activates a reading device and returns a Promise that either resolves when an NFC tag read operation is scheduled | ||
* or rejects if a hardware or permission error is encountered. This method triggers a permission prompt if the "nfc" | ||
* permission has not been previously granted. | ||
* | ||
* @return | ||
* a Promise that resolves immediately after scheduling read operations for the NFC adapter. | ||
*/ | ||
def scan(options: NDEFScanOptions = js.native): js.Promise[Unit] = js.native | ||
|
||
/** Attempts to write an NDEF message to a tag and returns a Promise that either resolves when a message has been | ||
* written to the tag or rejects if a hardware or permission error is encountered. This method triggers a permission | ||
* prompt if the "nfc" permission has not been previously granted. | ||
* | ||
* @param message | ||
* The message to be written, either a string object or literal, an ArrayBuffer, a TypedArray, a DataView, or an | ||
* array of records. A record has the following members: | ||
* @param options | ||
* An object with the following properties: | ||
* | ||
* @return | ||
* a Promise that either resolves when a message has been written to the tag or rejects if a hardware or permission | ||
* error is encountered. | ||
*/ | ||
def write(message: String, options: NDEFWriteOptions): js.Promise[Unit] = js.native | ||
def write(message: js.typedarray.ArrayBuffer, options: NDEFWriteOptions): js.Promise[Unit] = js.native | ||
|
||
def write(message: js.typedarray.TypedArray[_, _], | ||
options: NDEFWriteOptions = js.native): js.Promise[Unit] = js.native | ||
def write(message: js.typedarray.DataView, options: NDEFWriteOptions): js.Promise[Unit] = js.native | ||
def write(message: js.Array[NDEFRecord], options: NDEFWriteOptions): js.Promise[Unit] = js.native | ||
|
||
def write(message: String): js.Promise[Unit] = js.native | ||
def write(message: js.typedarray.ArrayBuffer): js.Promise[Unit] = js.native | ||
// def write(message:js.typedarray.TypedArray[NDEFRecord, ???]): js.Promise[Unit] = js.native | ||
def write(message: js.typedarray.DataView): js.Promise[Unit] = js.native | ||
def write(message: js.Array[NDEFRecord]): js.Promise[Unit] = js.native | ||
|
||
/** The reading event of the NDEFReader interface is fired whenever a new reading is available from compatible NFC | ||
* devices (e.g. NFC tags supporting NDEF) when these devices are within the reader's magnetic induction field. | ||
*/ | ||
var onreading: js.Function1[NDEFReadingEvent, Any] = js.native | ||
|
||
/** The readingerror event of the NDEFReader interface is fired whenever an error occurs during reading of NFC tags, | ||
* e.g. when tags leave the reader's magnetic induction field. | ||
*/ | ||
var onreadingerror: js.Function1[Event, Any] = js.native | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,25 @@ | ||
package org.scalajs.dom | ||
|
||
import scala.scalajs.js | ||
import scala.scalajs.js.annotation.JSGlobal | ||
|
||
/** The NDEFReadingEvent interface of the Web NFC API represents events dispatched on new NFC readings obtained by | ||
* NDEFReader. | ||
* | ||
* @see | ||
* https://developer.mozilla.org/en-US/docs/Web/API/NDEFReadingEvent | ||
* @see | ||
* https://w3c.github.io/web-nfc/#the-ndefreader-object | ||
*/ | ||
@js.native | ||
@JSGlobal | ||
class NDEFReadingEvent(typeArg: String, init: NDEFReadingEventInit) extends Event(typeArg, init) { | ||
|
||
/** Returns an NDEFMessage object containing the received message. */ | ||
def message: NDEFMessage = js.native | ||
|
||
/** Returns the serial number of the device, which is used for anti-collision and identification, or an empty string | ||
* if no serial number is available. | ||
*/ | ||
def serialNumber: String = js.native | ||
} |
24 changes: 24 additions & 0 deletions
24
dom/src/main/scala/org/scalajs/dom/NDEFReadingEventInit.scala
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,24 @@ | ||
package org.scalajs.dom | ||
|
||
import scala.scalajs.js | ||
|
||
/** NDEFReadingEventInit is used to initialize a new event with a serial number and the NDEFMessageInit data via the | ||
* message member. If serialNumber is not present or is null, empty string will be used to init the event. | ||
* | ||
* @see | ||
* https://developer.mozilla.org/en-US/docs/Web/API/NDEFReadingEvent/NDEFReadingEvent#parameters | ||
* @see | ||
* https://w3c.github.io/web-nfc/#the-ndefreader-object | ||
*/ | ||
trait NDEFReadingEventInit extends EventInit { | ||
|
||
/** A string with the name of the event. It is case-sensitive and browsers always set it to reading. Default is "" an | ||
* empty string | ||
*/ | ||
var serialNumber: js.UndefOr[AbortSignal] = js.undefined | ||
|
||
/** An object that, in addition of the properties defined in Event(), can have the following properties: serialNumber; | ||
* message | ||
*/ | ||
var message: NDEFRecordInit | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,44 @@ | ||
package org.scalajs.dom | ||
|
||
import scala.scalajs.js | ||
import scala.scalajs.js.annotation.JSGlobal | ||
|
||
/** The [[NDEFRecord]] interface of the Web NFC API provides data that can be read from, or written to, compatible NFC | ||
* devices, e.g. NFC tags supporting NDEF. | ||
* | ||
* @see | ||
* https://w3c.github.io/web-nfc/#the-ndefrecord-interface | ||
*/ | ||
@js.native | ||
@JSGlobal | ||
class NDEFRecord(init: NDEFRecordInit) extends js.Object { | ||
|
||
/** Returns the record type of the record. Records must have either a standardized well-known type name such as | ||
* "empty", "text", "url", "smart-poster", "absolute-url", "mime", or "unknown" or else an external type name, which | ||
* consists of a domain name and custom type name separated by a colon (":"). | ||
*/ | ||
def recordType: String = js.native | ||
|
||
/** Returns the MIME type of the record. This value will be null if recordType is not equal to "mime". */ | ||
def mediaType: js.UndefOr[String] = js.native | ||
|
||
/** Returns the record identifier, which is an absolute or relative URL used to identify the record. | ||
* | ||
* Note: The uniqueness of the identifier is enforced only by the generator of the record. | ||
*/ | ||
def id: js.UndefOr[String] = js.native | ||
|
||
/** Returns a DataView containing the raw bytes of the record's payload. */ | ||
def data: js.typedarray.DataView = js.native | ||
|
||
/** Returns the encoding of a textual payload, or null otherwise. */ | ||
def encoding: js.UndefOr[String] = js.native | ||
|
||
/** Returns the language of a textual payload, or null if one was not supplied. */ | ||
def lang: js.UndefOr[String] = js.native | ||
|
||
/** Converts [[NDEFRecord.data]] to a sequence of records. This allows parsing the payloads of record types which may | ||
* contain nested records, such as smart poster and external type records. | ||
*/ | ||
def toRecords(): js.UndefOr[js.Array[NDEFRecord]] = js.native | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,55 @@ | ||
package org.scalajs.dom | ||
|
||
import scala.scalajs.js | ||
import scala.scalajs.js.| | ||
|
||
/** The NDEFRecordInit dictionary is used to initialize an NDEF record with its record type recordType, and optional | ||
* record identifier id and payload data data. | ||
* @see | ||
* https://developer.mozilla.org/en-US/docs/Web/API/NDEFMessage/NDEFMessage | ||
* @see | ||
* https://developer.mozilla.org/en-US/docs/Web/API/NDEFRecord/NDEFRecord | ||
* @see | ||
* https://w3c.github.io/web-nfc/#the-ndefrecord-interface | ||
*/ | ||
trait NDEFRecordInit extends js.Object { | ||
|
||
/** Contains the data to be transmitted. It can be a string object or literal, an ArrayBuffer, a TypedArray, a | ||
* DataView, or an array of nested records. | ||
*/ | ||
var data: js.UndefOr[ | ||
String | | ||
js.typedarray.DataView | | ||
js.typedarray.ArrayBuffer | | ||
js.typedarray.TypedArray[_, _] | | ||
js.typedarray.DataView | | ||
js.Array[NDEFRecord] | ||
] = js.undefined | ||
|
||
/** A string specifying the record's encoding. */ | ||
var encoding: js.UndefOr[String] = js.undefined | ||
|
||
/** A developer-defined identifier for the record. */ | ||
var id: js.UndefOr[String] = js.undefined | ||
|
||
/** A valid language tag according to [RFC 5646: Tags for Identifying Languages (also known as BCP | ||
* 47)](https://datatracker.ietf.org/doc/html/rfc5646). | ||
*/ | ||
var lang: js.UndefOr[String] = js.undefined | ||
|
||
/** A valid MIME type. */ | ||
var mediaType: js.UndefOr[String] = js.undefined | ||
|
||
/** A string indicating the type of data stored in data. | ||
* | ||
* It must be one of the following values: | ||
* - "absolute-url" - An absolute URL to the data. | ||
* - "empty" - An empty NDEFRecord. | ||
* - "mime" - A valid MIME type. | ||
* - "smart-poster" - A smart poster as defined by the NDEF-SMARTPOSTER specification. | ||
* - "text" - Text as defined by the NDEF-TEXT specification. | ||
* - "unknown" - The record type is not known. | ||
* - "URL" - A URL as defined by the NDEF-URI specification. | ||
*/ | ||
var recordType: String | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,10 @@ | ||
package org.scalajs.dom | ||
|
||
import scala.scalajs.js | ||
|
||
/** @see https://w3c.github.io/web-nfc/#the-ndefscanoptions-dictionary */ | ||
trait NDEFScanOptions extends js.Object { | ||
|
||
/** An AbortSignal that allows the current write operation to be canceled. */ | ||
var `signal`: js.UndefOr[AbortSignal] = js.undefined | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
package org.scalajs.dom | ||
|
||
import scala.scalajs.js | ||
|
||
/** @see | ||
* https://w3c.github.io/web-nfc/#the-ndefwriteoptions-dictionary | ||
* @see | ||
* https://developer.mozilla.org/en-US/docs/Web/API/NDEFReader/write | ||
*/ | ||
trait NDEFWriteOptions extends js.Object { | ||
|
||
/** A boolean value specifying whether or not existing records should be overwritten, if such exists. Default is true | ||
*/ | ||
var `overwrite`: js.UndefOr[Boolean] = js.undefined | ||
|
||
/** An AbortSignal that allows the current write operation to be canceled. */ | ||
var `signal`: js.UndefOr[AbortSignal] = js.undefined | ||
|
||
} |