1 | var __extends = (this && this.__extends) || (function () {
|
2 | var extendStatics = function (d, b) {
|
3 | extendStatics = Object.setPrototypeOf ||
|
4 | ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
|
5 | function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
|
6 | return extendStatics(d, b);
|
7 | };
|
8 | return function (d, b) {
|
9 | extendStatics(d, b);
|
10 | function __() { this.constructor = d; }
|
11 | d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
|
12 | };
|
13 | })();
|
14 | import { IonicNativePlugin, cordova, checkAvailability, cordovaInstance, instancePropertyGet, instancePropertySet } from '@ionic-native/core';
|
15 | var SQLiteObject = /** @class */ (function () {
|
16 | function SQLiteObject(_objectInstance) {
|
17 | this._objectInstance = _objectInstance;
|
18 | }
|
19 | SQLiteObject.prototype.addTransaction = function (transaction) { return cordovaInstance(this, "addTransaction", { "sync": true }, arguments); };
|
20 | SQLiteObject.prototype.transaction = function (fn) { return cordovaInstance(this, "transaction", { "successIndex": 2, "errorIndex": 1 }, arguments); };
|
21 | SQLiteObject.prototype.readTransaction = function (fn) { return cordovaInstance(this, "readTransaction", {}, arguments); };
|
22 | SQLiteObject.prototype.startNextTransaction = function () { return cordovaInstance(this, "startNextTransaction", { "sync": true }, arguments); };
|
23 | SQLiteObject.prototype.open = function () { return cordovaInstance(this, "open", {}, arguments); };
|
24 | SQLiteObject.prototype.close = function () { return cordovaInstance(this, "close", {}, arguments); };
|
25 | SQLiteObject.prototype.executeSql = function (statement, params) { return cordovaInstance(this, "executeSql", {}, arguments); };
|
26 | SQLiteObject.prototype.sqlBatch = function (sqlStatements) { return cordovaInstance(this, "sqlBatch", {}, arguments); };
|
27 | SQLiteObject.prototype.abortallPendingTransactions = function () { return cordovaInstance(this, "abortallPendingTransactions", { "sync": true }, arguments); };
|
28 | Object.defineProperty(SQLiteObject.prototype, "databaseFeatures", {
|
29 | get: function () { return instancePropertyGet(this, "databaseFeatures"); },
|
30 | set: function (value) { instancePropertySet(this, "databaseFeatures", value); },
|
31 | enumerable: true,
|
32 | configurable: true
|
33 | });
|
34 | Object.defineProperty(SQLiteObject.prototype, "openDBs", {
|
35 | get: function () { return instancePropertyGet(this, "openDBs"); },
|
36 | set: function (value) { instancePropertySet(this, "openDBs", value); },
|
37 | enumerable: true,
|
38 | configurable: true
|
39 | });
|
40 | return SQLiteObject;
|
41 | }());
|
42 | export { SQLiteObject };
|
43 | var SQLiteOriginal = /** @class */ (function (_super) {
|
44 | __extends(SQLiteOriginal, _super);
|
45 | function SQLiteOriginal() {
|
46 | return _super !== null && _super.apply(this, arguments) || this;
|
47 | }
|
48 | SQLiteOriginal.prototype.create = function (config) {
|
49 | var _this = this;
|
50 | return (function () {
|
51 | if (checkAvailability(_this) === true) {
|
52 | return new Promise(function (resolve, reject) {
|
53 | sqlitePlugin.openDatabase(config, function (db) { return resolve(new SQLiteObject(db)); }, reject);
|
54 | });
|
55 | }
|
56 | })();
|
57 | };
|
58 | SQLiteOriginal.prototype.echoTest = function () { return cordova(this, "echoTest", {}, arguments); };
|
59 | SQLiteOriginal.prototype.selfTest = function () { return cordova(this, "selfTest", {}, arguments); };
|
60 | SQLiteOriginal.prototype.deleteDatabase = function (config) { return cordova(this, "deleteDatabase", {}, arguments); };
|
61 | SQLiteOriginal.pluginName = "SQLite";
|
62 | SQLiteOriginal.pluginRef = "sqlitePlugin";
|
63 | SQLiteOriginal.plugin = "cordova-sqlite-storage";
|
64 | SQLiteOriginal.repo = "https://github.com/litehelpers/Cordova-sqlite-storage";
|
65 | SQLiteOriginal.platforms = ["Android", "iOS", "macOS", "Windows"];
|
66 | return SQLiteOriginal;
|
67 | }(IonicNativePlugin));
|
68 | var SQLite = new SQLiteOriginal();
|
69 | export { SQLite };
|
70 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/@ionic-native/plugins/sqlite/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;AACA,OAAO,4GAON,MAAM,oBAAoB,CAAC;;IAyD1B,sBAAmB,eAAoB;QAApB,oBAAe,GAAf,eAAe,CAAK;IAAG,CAAC;IAQ3C,qCAAc,aAAC,WAA4C;IAU3D,kCAAW,aAAC,EAA+B;IAS3C,sCAAe,aAAC,EAAmC;IAOnD,2CAAoB;IAMpB,2BAAI;IAQJ,4BAAK;IASL,iCAAU,aAAC,SAAiB,EAAE,MAAc;IAS5C,+BAAQ,aAAC,aAA0C;IAOnD,kDAA2B;0BAvEP,0CAAgB;;;;;;0BAChB,iCAAO;;;;;;uBApE7B;;;;IA2L4B,0BAAiB;;;;IAU3C,uBAAM,aAAC,MAA4B;;;mDAAyB;gBAC1D,OAAO,IAAI,OAAO,CAAC,UAAC,OAAO,EAAE,MAAM;oBACjC,YAAY,CAAC,YAAY,CACvB,MAAM,EACN,UAAC,EAAO,IAAK,OAAA,OAAO,CAAC,IAAI,YAAY,CAAC,EAAE,CAAC,CAAC,EAA7B,CAA6B,EAC1C,MAAM,CACP,CAAC;gBACJ,CAAC,CAAC,CAAC;aACJ;;;IAOD,yBAAQ;IASR,yBAAQ;IAUR,+BAAc,aAAC,MAA4B;;;;;;iBAvO7C;EA2L4B,iBAAiB;SAAhC,MAAM","sourcesContent":["import { Injectable } from '@angular/core';\nimport {\n  Cordova,\n  CordovaCheck,\n  CordovaInstance,\n  InstanceProperty,\n  IonicNativePlugin,\n  Plugin\n} from '@ionic-native/core';\n\ndeclare const sqlitePlugin: any;\n\nexport interface SQLiteDatabaseConfig {\n  /**\n   * Name of the database. Example: 'my.db'\n   */\n  name: string;\n  /**\n   * Location of the database. Example: 'default'\n   */\n  location?: string;\n  /**\n   * iOS Database Location. Example: 'Library'\n   */\n  iosDatabaseLocation?: string;\n  /**\n   * support opening pre-filled databases with https://github.com/litehelpers/cordova-sqlite-ext\n   */\n  createFromLocation?: number;\n  /**\n   * support encrypted databases with https://github.com/litehelpers/Cordova-sqlcipher-adapter\n   */\n  key?: string;\n}\n\n/**\n * @hidden\n */\nexport interface DbTransaction {\n  executeSql: (\n    sql: any,\n    values?: any[],\n    success?: Function,\n    error?: Function\n  ) => void;\n}\n\n/**\n * @hidden\n */\nexport interface SQLiteTransaction extends DbTransaction {\n  start: () => void;\n  addStatement: DbTransaction['executeSql'];\n  handleStatementSuccess: (handler: Function, response: any) => void;\n  handleStatementFailure: (handler: Function, response: any) => void;\n  run: () => void;\n  abort: (txFailure: any) => void;\n  finish: () => void;\n  abortFromQ: (sqlerror: any) => void;\n}\n\n/**\n * @hidden\n */\nexport class SQLiteObject {\n  constructor(public _objectInstance: any) {}\n\n  @InstanceProperty() databaseFeatures: { isSQLitePluginDatabase: boolean };\n  @InstanceProperty() openDBs: any;\n\n  @CordovaInstance({\n    sync: true\n  })\n  addTransaction(transaction: (tx: SQLiteTransaction) => void): void {}\n\n  /**\n   * @param fn {Function}\n   * @returns {Promise<any>}\n   */\n  @CordovaInstance({\n    successIndex: 2,\n    errorIndex: 1\n  })\n  transaction(fn: (tx: DbTransaction) => void): Promise<any> {\n    return;\n  }\n\n  /**\n   * @param fn {Function}\n   * @returns {Promise<any>}\n   */\n  @CordovaInstance()\n  readTransaction(fn: (tx: SQLiteTransaction) => void): Promise<any> {\n    return;\n  }\n\n  @CordovaInstance({\n    sync: true\n  })\n  startNextTransaction(): void {}\n\n  /**\n   * @returns {Promise<any>}\n   */\n  @CordovaInstance()\n  open(): Promise<any> {\n    return;\n  }\n\n  /**\n   * @returns {Promise<any>}\n   */\n  @CordovaInstance()\n  close(): Promise<any> {\n    return;\n  }\n\n  /**\n   * Execute SQL on the opened database. Note, you must call `create` first, and\n   * ensure it resolved and successfully opened the database.\n   */\n  @CordovaInstance()\n  executeSql(statement: string, params?: any[]): Promise<any> {\n    return;\n  }\n\n  /**\n   * @param sqlStatements {string[] | string[][] | any[]}\n   * @returns {Promise<any>}\n   */\n  @CordovaInstance()\n  sqlBatch(sqlStatements: (string | string[] | any)[]): Promise<any> {\n    return;\n  }\n\n  @CordovaInstance({\n    sync: true\n  })\n  abortallPendingTransactions(): void {}\n}\n\n/**\n * @name SQLite\n *\n * @description\n * Access SQLite databases on the device.\n *\n * @usage\n *\n * ```typescript\n * import { SQLite, SQLiteObject } from '@ionic-native/sqlite/ngx';\n *\n * constructor(private sqlite: SQLite) { }\n *\n * ...\n *\n * this.sqlite.create({\n *   name: 'data.db',\n *   location: 'default'\n * })\n *   .then((db: SQLiteObject) => {\n *\n *\n *     db.executeSql('create table danceMoves(name VARCHAR(32))', [])\n *       .then(() => console.log('Executed SQL'))\n *       .catch(e => console.log(e));\n *\n *\n *   })\n *   .catch(e => console.log(e));\n *\n * ```\n *\n * @classes\n * SQLiteObject\n * @interfaces\n * SQLiteDatabaseConfig\n * SQLiteTransaction\n */\n@Plugin({\n  pluginName: 'SQLite',\n  pluginRef: 'sqlitePlugin',\n  plugin: 'cordova-sqlite-storage',\n  repo: 'https://github.com/litehelpers/Cordova-sqlite-storage',\n  platforms: ['Android', 'iOS', 'macOS', 'Windows']\n})\n@Injectable()\nexport class SQLite extends IonicNativePlugin {\n  /**\n   * Open or create a SQLite database file.\n   *\n   * See the plugin docs for an explanation of all options: https://github.com/litehelpers/Cordova-sqlite-storage#opening-a-database\n   *\n   * @param config {SQLiteDatabaseConfig} database configuration\n   * @return Promise<SQLiteObject>\n   */\n  @CordovaCheck()\n  create(config: SQLiteDatabaseConfig): Promise<SQLiteObject> {\n    return new Promise((resolve, reject) => {\n      sqlitePlugin.openDatabase(\n        config,\n        (db: any) => resolve(new SQLiteObject(db)),\n        reject\n      );\n    });\n  }\n\n  /**\n   * Verify that both the Javascript and native part of this plugin are installed in your application\n   * @returns {Promise<any>}\n   */\n  @Cordova()\n  echoTest(): Promise<any> {\n    return;\n  }\n\n  /**\n   * Automatically verify basic database access operations including opening a database\n   * @returns {Promise<any>}\n   */\n  @Cordova()\n  selfTest(): Promise<any> {\n    return;\n  }\n\n  /**\n   * Deletes a database\n   * @param config {SQLiteDatabaseConfig} database configuration\n   * @returns {Promise<any>}\n   */\n  @Cordova()\n  deleteDatabase(config: SQLiteDatabaseConfig): Promise<any> {\n    return;\n  }\n}\n"]} |
\ | No newline at end of file |