2021-05-22 14:26:31 +05:30
|
|
|
import {
|
|
|
|
Application,
|
|
|
|
AndroidApplication,
|
|
|
|
Utils,
|
|
|
|
Device,
|
|
|
|
Color,
|
|
|
|
path,
|
|
|
|
knownFolders,
|
|
|
|
} from '@nativescript/core'
|
2021-06-05 23:39:42 +05:30
|
|
|
import { localize } from '@nativescript/localize'
|
|
|
|
|
2021-04-07 22:48:38 +05:30
|
|
|
let timerOne
|
2021-05-25 20:02:53 +05:30
|
|
|
declare const global, android, androidx, com, java, Array: any
|
|
|
|
|
2021-06-05 23:39:42 +05:30
|
|
|
const PowerManager = android.os.PowerManager
|
|
|
|
const pm = Utils.android
|
|
|
|
.getApplicationContext()
|
|
|
|
.getSystemService(android.content.Context.POWER_SERVICE)
|
|
|
|
const wl = pm.newWakeLock(PowerManager.PARTIAL_WAKE_LOCK, 'Timers')
|
|
|
|
|
2020-11-23 15:19:58 +05:30
|
|
|
export const restartApp = () => {
|
2021-05-22 14:26:31 +05:30
|
|
|
const ctx = Utils.ad.getApplicationContext()
|
2021-04-01 16:25:35 +05:30
|
|
|
let mStartActivity = new android.content.Intent(
|
2021-05-22 14:26:31 +05:30
|
|
|
ctx,
|
2021-02-28 23:04:27 +05:30
|
|
|
Application.android.startActivity.getClass()
|
|
|
|
)
|
2021-04-01 16:25:35 +05:30
|
|
|
let mPendingIntentId = Math.random() * 100000
|
|
|
|
let mPendingIntent = android.app.PendingIntent.getActivity(
|
2021-05-22 14:26:31 +05:30
|
|
|
ctx,
|
2021-02-28 23:04:27 +05:30
|
|
|
mPendingIntentId,
|
|
|
|
mStartActivity,
|
|
|
|
android.app.PendingIntent.FLAG_CANCEL_CURRENT
|
|
|
|
)
|
2021-05-22 14:26:31 +05:30
|
|
|
let mgr = ctx.getSystemService(android.content.Context.ALARM_SERVICE)
|
2021-02-28 23:04:27 +05:30
|
|
|
mgr.set(
|
|
|
|
android.app.AlarmManager.RTC,
|
|
|
|
java.lang.System.currentTimeMillis() + 100,
|
|
|
|
mPendingIntent
|
|
|
|
)
|
2020-11-23 15:19:58 +05:30
|
|
|
android.os.Process.killProcess(android.os.Process.myPid())
|
|
|
|
}
|
|
|
|
export const openAppSettingsPage = () => {
|
2021-04-01 16:25:35 +05:30
|
|
|
let intent = new android.content.Intent(
|
2021-02-28 23:04:27 +05:30
|
|
|
android.provider.Settings.ACTION_APPLICATION_DETAILS_SETTINGS
|
|
|
|
)
|
2020-11-23 15:19:58 +05:30
|
|
|
intent.addCategory(android.content.Intent.CATEGORY_DEFAULT)
|
2021-02-28 23:04:27 +05:30
|
|
|
intent.setData(
|
|
|
|
android.net.Uri.parse(
|
|
|
|
'package:' + Application.android.context.getPackageName()
|
|
|
|
)
|
|
|
|
)
|
2020-11-23 15:19:58 +05:30
|
|
|
Application.android.foregroundActivity.startActivity(intent)
|
|
|
|
}
|
2021-02-28 23:04:27 +05:30
|
|
|
export const hasAccelerometer = () => {
|
2021-04-14 14:57:40 +05:30
|
|
|
let ctx = Utils.ad.getApplicationContext()
|
|
|
|
let sensorManager = ctx.getSystemService(
|
2021-02-28 23:04:27 +05:30
|
|
|
android.content.Context.SENSOR_SERVICE
|
|
|
|
)
|
|
|
|
return sensorManager.getDefaultSensor(
|
|
|
|
android.hardware.Sensor.TYPE_ACCELEROMETER
|
|
|
|
)
|
|
|
|
}
|
2021-04-01 16:25:35 +05:30
|
|
|
export const vibrate = (duration) => {
|
|
|
|
let vibratorService = Application.android.context.getSystemService(
|
|
|
|
android.content.Context.VIBRATOR_SERVICE
|
|
|
|
)
|
|
|
|
if (vibratorService.hasVibrator()) vibratorService.vibrate(duration)
|
|
|
|
}
|
2021-04-07 22:48:38 +05:30
|
|
|
export const timer = (dur, callback) => {
|
|
|
|
callback(true)
|
2021-06-05 23:39:42 +05:30
|
|
|
clearInterval(timerOne)
|
2021-04-07 22:48:38 +05:30
|
|
|
timerOne = setInterval(() => {
|
|
|
|
dur--
|
|
|
|
callback(true)
|
|
|
|
if (dur == 0) {
|
|
|
|
clearInterval(timerOne)
|
2021-06-05 23:39:42 +05:30
|
|
|
callback(false)
|
2021-04-07 22:48:38 +05:30
|
|
|
}
|
|
|
|
}, 1000)
|
|
|
|
}
|
|
|
|
|
2021-04-14 14:57:40 +05:30
|
|
|
function callIntent(ctx, intent, msg, pickerType) {
|
|
|
|
return new Promise((resolve) => {
|
2021-04-07 22:48:38 +05:30
|
|
|
const onEvent = function(e) {
|
|
|
|
if (e.requestCode === pickerType) {
|
|
|
|
resolve(e)
|
|
|
|
Application.android.off(AndroidApplication.activityResultEvent, onEvent)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
Application.android.once(AndroidApplication.activityResultEvent, onEvent)
|
2021-04-14 14:57:40 +05:30
|
|
|
ctx.startActivityForResult(
|
2021-04-12 23:39:48 +05:30
|
|
|
android.content.Intent.createChooser(intent, msg),
|
|
|
|
pickerType
|
|
|
|
)
|
2021-04-07 22:48:38 +05:30
|
|
|
})
|
|
|
|
}
|
2021-04-12 23:39:48 +05:30
|
|
|
// IMAGE PICKER
|
|
|
|
export const getRecipePhoto = () => {
|
2021-04-14 14:57:40 +05:30
|
|
|
const ctx =
|
2021-04-12 23:39:48 +05:30
|
|
|
Application.android.foregroundActivity || Application.android.startActivity
|
|
|
|
const DIR_CODE = Math.round(Math.random() * 10000)
|
|
|
|
const intent = new android.content.Intent(
|
|
|
|
android.content.Intent.ACTION_GET_CONTENT
|
|
|
|
)
|
|
|
|
intent.setType('image/*')
|
2021-05-25 20:02:53 +05:30
|
|
|
return callIntent(ctx, intent, 'Select photo', DIR_CODE).then(
|
|
|
|
({ resultCode, intent }: any) => {
|
|
|
|
if (resultCode === android.app.Activity.RESULT_OK)
|
|
|
|
if (intent != null && intent.getData()) return intent.getData()
|
|
|
|
}
|
|
|
|
)
|
2021-04-07 22:48:38 +05:30
|
|
|
}
|
2021-04-12 23:39:48 +05:30
|
|
|
export const copyPhotoToCache = (uri, filepath) => {
|
2021-04-07 22:48:38 +05:30
|
|
|
const ContentResolver = Application.android.nativeApp.getContentResolver()
|
2021-04-12 23:39:48 +05:30
|
|
|
return new Promise((resolve) => {
|
|
|
|
const inputStream = ContentResolver.openInputStream(uri)
|
|
|
|
const input = new java.io.BufferedInputStream(inputStream)
|
|
|
|
let size = input.available()
|
|
|
|
let buffer = Array.create('byte', size)
|
|
|
|
const output = new java.io.BufferedOutputStream(
|
|
|
|
new java.io.FileOutputStream(filepath)
|
|
|
|
)
|
|
|
|
input.read(buffer)
|
|
|
|
do {
|
|
|
|
output.write(buffer)
|
|
|
|
} while (input.read(buffer) != -1)
|
|
|
|
input.close()
|
|
|
|
output.close()
|
|
|
|
resolve(filepath)
|
|
|
|
})
|
2021-04-07 22:48:38 +05:30
|
|
|
}
|
|
|
|
|
2021-05-22 14:26:31 +05:30
|
|
|
// COPY DB FILE
|
|
|
|
export const copyDBToExport = () => {
|
|
|
|
const src = path.join(knownFolders.documents().path, 'EnRecipes.db')
|
|
|
|
const dst = path.join(
|
|
|
|
knownFolders.documents().getFolder('EnRecipes').path,
|
|
|
|
'EnRecipes.db'
|
|
|
|
)
|
|
|
|
const input = new java.io.FileInputStream(src)
|
|
|
|
try {
|
|
|
|
const output = new java.io.FileOutputStream(dst)
|
2021-05-25 20:02:53 +05:30
|
|
|
let len: number
|
2021-05-22 14:26:31 +05:30
|
|
|
let buffer = Array.create('byte', 1024)
|
|
|
|
while ((len = input.read(buffer)) > 0) output.write(buffer, 0, len)
|
|
|
|
} catch (error) {
|
|
|
|
console.log(error)
|
|
|
|
} finally {
|
|
|
|
input.close()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-04-12 23:39:48 +05:30
|
|
|
// BACKUP FOLDER PICKER
|
|
|
|
export const getBackupFolder = () => {
|
2021-04-14 14:57:40 +05:30
|
|
|
const ctx =
|
2021-04-07 22:48:38 +05:30
|
|
|
Application.android.foregroundActivity || Application.android.startActivity
|
|
|
|
const DIR_CODE = Math.round(Math.random() * 10000)
|
|
|
|
const intent = new android.content.Intent(
|
|
|
|
android.content.Intent.ACTION_OPEN_DOCUMENT_TREE
|
|
|
|
)
|
2021-05-25 20:02:53 +05:30
|
|
|
return callIntent(ctx, intent, 'Select folder', DIR_CODE).then(
|
|
|
|
({ resultCode, intent }: any) => {
|
|
|
|
if (resultCode === android.app.Activity.RESULT_OK)
|
|
|
|
if (intent != null && intent.getData()) return intent.getData()
|
|
|
|
}
|
|
|
|
)
|
2021-04-07 22:48:38 +05:30
|
|
|
}
|
|
|
|
|
2021-04-12 23:39:48 +05:30
|
|
|
// BACKUP FILE PICKER
|
2021-04-07 22:48:38 +05:30
|
|
|
export const getBackupFile = () => {
|
2021-04-14 14:57:40 +05:30
|
|
|
const ctx =
|
2021-04-07 22:48:38 +05:30
|
|
|
Application.android.foregroundActivity || Application.android.startActivity
|
|
|
|
const DIR_CODE = Math.round(Math.random() * 10000)
|
|
|
|
const intent = new android.content.Intent(
|
|
|
|
android.content.Intent.ACTION_GET_CONTENT
|
|
|
|
)
|
|
|
|
intent.addCategory(android.content.Intent.CATEGORY_OPENABLE)
|
|
|
|
intent.setType('application/zip')
|
2021-04-14 14:57:40 +05:30
|
|
|
return callIntent(ctx, intent, 'Select file to import', DIR_CODE).then(
|
2021-05-25 20:02:53 +05:30
|
|
|
({ resultCode, intent }: any) => {
|
|
|
|
if (resultCode === android.app.Activity.RESULT_OK) {
|
|
|
|
if (intent != null && intent.getData()) return intent.getData()
|
2021-04-07 22:48:38 +05:30
|
|
|
}
|
|
|
|
}
|
2021-04-12 23:39:48 +05:30
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
// ZIP OPERATIONS
|
|
|
|
export class Zip {
|
2021-05-25 20:02:53 +05:30
|
|
|
static getSubFiles(src: string, isRootFolder?: boolean) {
|
2021-04-12 23:39:48 +05:30
|
|
|
const fileList = new java.util.ArrayList()
|
|
|
|
const sourceFile = new java.io.File(src)
|
|
|
|
let tempList = sourceFile.listFiles()
|
|
|
|
for (let i = 0; i < tempList.length; i++) {
|
|
|
|
if (tempList[i].isFile()) {
|
|
|
|
fileList.add(tempList[i])
|
|
|
|
}
|
|
|
|
if (tempList[i].isDirectory()) {
|
|
|
|
if (isRootFolder) {
|
|
|
|
fileList.add(tempList[i])
|
|
|
|
}
|
|
|
|
fileList.addAll(Zip.getSubFiles(tempList[i].getAbsolutePath()))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return fileList
|
|
|
|
}
|
|
|
|
static zip(src, destUri, filename) {
|
|
|
|
const ContentResolver = Application.android.nativeApp.getContentResolver()
|
|
|
|
const parsedUri = new android.net.Uri.parse(destUri)
|
|
|
|
const uri = new androidx.documentfile.provider.DocumentFile.fromTreeUri(
|
|
|
|
Application.android.context,
|
|
|
|
parsedUri
|
|
|
|
)
|
2021-04-18 18:58:07 +05:30
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
if (uri.exists()) {
|
|
|
|
let destFile = uri.createFile('application/zip', filename).getUri()
|
|
|
|
const outputStream = ContentResolver.openOutputStream(destFile)
|
|
|
|
const zipOutputStream = new java.util.zip.ZipOutputStream(outputStream)
|
|
|
|
const sourceFiles = Zip.getSubFiles(src, true)
|
|
|
|
for (let i = 0; i < sourceFiles.size(); i++) {
|
|
|
|
let len
|
|
|
|
let buffer = Array.create('byte', 4096)
|
|
|
|
let file = sourceFiles.get(i)
|
|
|
|
let entry = new java.util.zip.ZipEntry(
|
|
|
|
'EnRecipes/' +
|
|
|
|
new java.io.File(src)
|
|
|
|
.toURI()
|
|
|
|
.relativize(file.toURI())
|
|
|
|
.getPath()
|
|
|
|
)
|
|
|
|
zipOutputStream.putNextEntry(entry)
|
|
|
|
if (!file.isDirectory()) {
|
|
|
|
let inputStream = new java.io.FileInputStream(file)
|
|
|
|
while ((len = inputStream.read(buffer)) != -1) {
|
|
|
|
zipOutputStream.write(buffer, 0, len)
|
|
|
|
}
|
|
|
|
inputStream.close()
|
2021-04-12 23:39:48 +05:30
|
|
|
}
|
2021-04-18 18:58:07 +05:30
|
|
|
zipOutputStream.closeEntry()
|
2021-04-12 23:39:48 +05:30
|
|
|
}
|
2021-04-18 18:58:07 +05:30
|
|
|
zipOutputStream.close()
|
|
|
|
resolve(destFile)
|
|
|
|
} else {
|
|
|
|
reject('Destination file cannot be created: Path does not exist')
|
2021-04-12 23:39:48 +05:30
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
static unzip(uri, dest) {
|
|
|
|
const ContentResolver = Application.android.nativeApp.getContentResolver()
|
|
|
|
return new Promise((resolve) => {
|
|
|
|
const inputStream = ContentResolver.openInputStream(uri)
|
|
|
|
const zipInputStream = new java.util.zip.ZipInputStream(inputStream)
|
2021-04-18 18:58:07 +05:30
|
|
|
let len, filepath, entry
|
|
|
|
while ((entry = zipInputStream.getNextEntry()) != null) {
|
2021-04-12 23:39:48 +05:30
|
|
|
filepath = dest + '/' + entry.getName()
|
2021-04-18 18:58:07 +05:30
|
|
|
let output = new java.io.File(filepath)
|
|
|
|
if (entry.isDirectory()) {
|
|
|
|
output.mkdirs()
|
|
|
|
continue
|
2021-04-12 23:39:48 +05:30
|
|
|
}
|
2021-04-18 18:58:07 +05:30
|
|
|
if (!output.getParentFile().exists()) output.getParentFile().mkdirs()
|
|
|
|
const outputStream = new java.io.BufferedOutputStream(
|
|
|
|
new java.io.FileOutputStream(output)
|
|
|
|
)
|
|
|
|
let buffer = Array.create('byte', 4096)
|
|
|
|
while ((len = zipInputStream.read(buffer)) != -1)
|
|
|
|
outputStream.write(buffer, 0, len)
|
|
|
|
outputStream.close()
|
2021-04-12 23:39:48 +05:30
|
|
|
zipInputStream.closeEntry()
|
|
|
|
}
|
|
|
|
zipInputStream.close()
|
|
|
|
resolve(dest)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// SHARE OPERATIONS
|
|
|
|
|
|
|
|
function share(intent, subject) {
|
2021-04-14 14:57:40 +05:30
|
|
|
const ctx = Application.android.context
|
2021-04-12 23:39:48 +05:30
|
|
|
const shareIntent = android.content.Intent.createChooser(intent, subject)
|
|
|
|
shareIntent.setFlags(android.content.Intent.FLAG_ACTIVITY_NEW_TASK)
|
2021-04-14 14:57:40 +05:30
|
|
|
ctx.startActivity(shareIntent)
|
|
|
|
}
|
|
|
|
function getSendIntent(type) {
|
|
|
|
const intent = new android.content.Intent(android.content.Intent.ACTION_SEND)
|
|
|
|
intent.setType(type)
|
|
|
|
return intent
|
2021-04-12 23:39:48 +05:30
|
|
|
}
|
|
|
|
export const shareText = (text, subject) => {
|
2021-04-14 14:57:40 +05:30
|
|
|
const intent = getSendIntent('text/plain')
|
|
|
|
intent.putExtra(android.content.Intent.EXTRA_TEXT, text)
|
|
|
|
share(intent, subject)
|
|
|
|
}
|
2021-06-05 23:39:42 +05:30
|
|
|
export const shareImage = (image, subject, title) => {
|
2021-04-14 14:57:40 +05:30
|
|
|
let ctx = Application.android.context
|
|
|
|
const intent = getSendIntent('image/jpeg')
|
|
|
|
const baos = new java.io.ByteArrayOutputStream()
|
|
|
|
image.android.compress(android.graphics.Bitmap.CompressFormat.JPEG, 100, baos)
|
2021-06-05 23:39:42 +05:30
|
|
|
const tmpFile = new java.io.File(ctx.getCacheDir(), `${title}.jpg`)
|
2021-04-14 14:57:40 +05:30
|
|
|
const fos = new java.io.FileOutputStream(tmpFile)
|
|
|
|
fos.write(baos.toByteArray())
|
|
|
|
fos.flush()
|
|
|
|
fos.close()
|
2021-04-18 21:38:58 +05:30
|
|
|
let shareUri = global.androidx.core.content.FileProvider.getUriForFile(
|
|
|
|
ctx,
|
|
|
|
Application.android.nativeApp.getPackageName() + '.provider',
|
|
|
|
tmpFile
|
2021-04-14 14:57:40 +05:30
|
|
|
)
|
2021-04-18 21:38:58 +05:30
|
|
|
intent.putExtra(android.content.Intent.EXTRA_STREAM, shareUri)
|
2021-04-12 23:39:48 +05:30
|
|
|
share(intent, subject)
|
2021-04-07 22:48:38 +05:30
|
|
|
}
|
2021-05-22 14:26:31 +05:30
|
|
|
|
2021-06-05 23:39:42 +05:30
|
|
|
export const keepScreenOn = (bool) => {
|
|
|
|
let ctx =
|
|
|
|
Application.android.foregroundActivity || Application.android.startActivity
|
|
|
|
let window = ctx.getWindow()
|
|
|
|
let flag = android.view.WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON
|
|
|
|
bool ? window.addFlags(flag) : window.clearFlags(flag)
|
|
|
|
}
|
|
|
|
|
2021-05-22 14:26:31 +05:30
|
|
|
// TIMER NOTIFICATION
|
2021-05-25 20:02:53 +05:30
|
|
|
export class TimerNotif {
|
|
|
|
static getIcon(ctx, icon) {
|
2021-05-22 14:26:31 +05:30
|
|
|
const packageName = ctx.getApplicationInfo().packageName
|
|
|
|
let resources = ctx.getResources()
|
|
|
|
return (
|
|
|
|
resources.getIdentifier(icon, 'drawable', packageName) ||
|
|
|
|
ctx.getApplicationInfo().icon
|
|
|
|
)
|
|
|
|
}
|
|
|
|
static clear(nID) {
|
|
|
|
let ctx = Utils.ad.getApplicationContext()
|
|
|
|
const NotifySrv = ctx.getSystemService(
|
|
|
|
android.content.Context.NOTIFICATION_SERVICE
|
|
|
|
)
|
2021-05-26 21:14:50 +05:30
|
|
|
// nID ? NotifySrv.cancel(nID) : NotifySrv.cancelAll()
|
2021-05-22 14:26:31 +05:30
|
|
|
NotifySrv.cancel(nID)
|
|
|
|
}
|
2021-05-26 21:14:50 +05:30
|
|
|
static getNotification(
|
|
|
|
{
|
2021-06-05 23:39:42 +05:30
|
|
|
multi,
|
2021-05-26 21:14:50 +05:30
|
|
|
actions,
|
|
|
|
bID,
|
|
|
|
cID,
|
|
|
|
cName,
|
|
|
|
description,
|
|
|
|
priority,
|
|
|
|
sound,
|
|
|
|
title,
|
|
|
|
vibrate,
|
|
|
|
}: {
|
2021-06-05 23:39:42 +05:30
|
|
|
multi?: boolean
|
2021-05-26 21:14:50 +05:30
|
|
|
actions?: boolean
|
|
|
|
bID: string
|
|
|
|
cID: string
|
|
|
|
cName: string
|
|
|
|
description: string
|
|
|
|
priority: number
|
|
|
|
sound: string
|
|
|
|
title: string
|
|
|
|
vibrate?: number
|
|
|
|
},
|
|
|
|
ctx
|
|
|
|
) {
|
2021-05-25 20:02:53 +05:30
|
|
|
let sdkv: number = parseInt(Device.sdkVersion)
|
|
|
|
let soundUri: any
|
2021-05-22 14:26:31 +05:30
|
|
|
if (sound) soundUri = new android.net.Uri.parse(sound)
|
|
|
|
const NotifyMgr = android.app.NotificationManager
|
|
|
|
const NotifySrv = ctx.getSystemService(
|
|
|
|
android.content.Context.NOTIFICATION_SERVICE
|
|
|
|
)
|
2021-05-26 21:14:50 +05:30
|
|
|
const NotificationCompat = androidx.core.app.NotificationCompat
|
|
|
|
const AudioManager = android.media.AudioManager
|
2021-05-22 14:26:31 +05:30
|
|
|
if (sdkv >= 26) {
|
2021-05-25 20:02:53 +05:30
|
|
|
const importance =
|
|
|
|
priority > 0 ? NotifyMgr.IMPORTANCE_HIGH : NotifyMgr.IMPORTANCE_MIN
|
2021-05-22 14:26:31 +05:30
|
|
|
const AudioAttributes = android.media.AudioAttributes
|
|
|
|
const audioAttributes = new AudioAttributes.Builder()
|
2021-05-25 20:02:53 +05:30
|
|
|
.setContentType(AudioAttributes.CONTENT_TYPE_SONIFICATION)
|
2021-05-22 14:26:31 +05:30
|
|
|
.setUsage(AudioAttributes.USAGE_ALARM)
|
|
|
|
.build()
|
|
|
|
const Channel = new android.app.NotificationChannel(
|
|
|
|
cID,
|
|
|
|
cName,
|
|
|
|
importance
|
|
|
|
)
|
|
|
|
if (description) Channel.setDescription(description)
|
|
|
|
Channel.enableVibration(vibrate)
|
|
|
|
Channel.enableLights(false)
|
|
|
|
if (sound) Channel.setSound(soundUri, audioAttributes)
|
|
|
|
else Channel.setSound(null, null)
|
|
|
|
Channel.setShowBadge(true)
|
2021-05-26 21:14:50 +05:30
|
|
|
Channel.setLockscreenVisibility(NotificationCompat.VISIBILITY_PUBLIC)
|
2021-05-22 14:26:31 +05:30
|
|
|
NotifySrv.createNotificationChannel(Channel)
|
|
|
|
}
|
|
|
|
|
|
|
|
const Intent = android.content.Intent
|
|
|
|
const PendingIntent = android.app.PendingIntent
|
|
|
|
|
|
|
|
const mainInt = new Intent(ctx, com.tns.NativeScriptActivity.class)
|
2021-06-05 23:39:42 +05:30
|
|
|
mainInt.putExtra('action', 'timer')
|
2021-05-22 14:26:31 +05:30
|
|
|
const mainPInt = PendingIntent.getActivity(
|
|
|
|
ctx,
|
|
|
|
1,
|
|
|
|
mainInt,
|
|
|
|
PendingIntent.FLAG_UPDATE_CURRENT
|
|
|
|
)
|
|
|
|
|
|
|
|
// Action intent
|
2021-06-05 23:39:42 +05:30
|
|
|
let actionInt1,
|
|
|
|
actionInt2,
|
|
|
|
actionInt3,
|
|
|
|
actionPInt1,
|
|
|
|
actionPInt2,
|
|
|
|
actionPInt3
|
2021-05-22 14:26:31 +05:30
|
|
|
if (actions) {
|
|
|
|
actionInt1 = new Intent(bID)
|
2021-06-05 23:39:42 +05:30
|
|
|
actionInt1.putExtra('action', 'delay')
|
2021-05-22 14:26:31 +05:30
|
|
|
actionPInt1 = PendingIntent.getBroadcast(
|
|
|
|
ctx,
|
|
|
|
2,
|
|
|
|
actionInt1,
|
|
|
|
PendingIntent.FLAG_UPDATE_CURRENT
|
|
|
|
)
|
|
|
|
actionInt2 = new Intent(bID)
|
2021-06-05 23:39:42 +05:30
|
|
|
actionInt2.putExtra('action', 'dismiss')
|
2021-05-22 14:26:31 +05:30
|
|
|
actionPInt2 = PendingIntent.getBroadcast(
|
|
|
|
ctx,
|
|
|
|
3,
|
|
|
|
actionInt2,
|
|
|
|
PendingIntent.FLAG_UPDATE_CURRENT
|
|
|
|
)
|
2021-06-05 23:39:42 +05:30
|
|
|
actionInt3 = new Intent(bID)
|
|
|
|
actionInt3.putExtra('action', 'dismissAll')
|
|
|
|
actionPInt3 = PendingIntent.getBroadcast(
|
|
|
|
ctx,
|
|
|
|
4,
|
|
|
|
actionInt3,
|
|
|
|
PendingIntent.FLAG_UPDATE_CURRENT
|
|
|
|
)
|
2021-05-22 14:26:31 +05:30
|
|
|
}
|
|
|
|
|
|
|
|
// CREATE NOTIFICATION
|
2021-05-26 21:14:50 +05:30
|
|
|
|
2021-06-05 23:39:42 +05:30
|
|
|
let icon = this.getIcon(ctx, 'notify_icon_sil')
|
2021-05-22 14:26:31 +05:30
|
|
|
let builder = new NotificationCompat.Builder(ctx, cID)
|
|
|
|
.setColor(new Color('#ff5200').android)
|
|
|
|
.setContentIntent(mainPInt)
|
|
|
|
.setContentTitle(title)
|
|
|
|
.setOngoing(true)
|
|
|
|
.setPriority(priority)
|
|
|
|
.setShowWhen(actions)
|
|
|
|
.setSmallIcon(icon)
|
|
|
|
.setTicker(title)
|
|
|
|
.setAutoCancel(false)
|
2021-05-26 21:14:50 +05:30
|
|
|
.setVisibility(NotificationCompat.VISIBILITY_PUBLIC)
|
2021-05-25 20:02:53 +05:30
|
|
|
if (sound) builder.setSound(soundUri, AudioManager.STREAM_ALARM)
|
|
|
|
else builder.setSound(null)
|
2021-05-22 14:26:31 +05:30
|
|
|
if (description) builder.setContentText(description)
|
|
|
|
if (vibrate) builder.setVibrate([500, 1000])
|
|
|
|
if (actions) {
|
|
|
|
builder.setFullScreenIntent(mainPInt, true)
|
2021-06-05 23:39:42 +05:30
|
|
|
if (multi) builder.addAction(null, localize('dismissAll'), actionPInt3)
|
|
|
|
else {
|
|
|
|
builder.addAction(null, localize('delay'), actionPInt1)
|
|
|
|
builder.addAction(null, localize('dismiss'), actionPInt2)
|
|
|
|
}
|
2021-05-22 14:26:31 +05:30
|
|
|
}
|
|
|
|
let notification = builder.build()
|
2021-05-25 20:02:53 +05:30
|
|
|
notification.flags =
|
|
|
|
NotificationCompat.FLAG_INSISTENT | NotificationCompat.FLAG_ONGOING_EVENT
|
2021-05-26 21:14:50 +05:30
|
|
|
|
|
|
|
return notification
|
|
|
|
}
|
|
|
|
static show(data) {
|
|
|
|
const ctx = Utils.ad.getApplicationContext()
|
|
|
|
const NotifySrv = ctx.getSystemService(
|
|
|
|
android.content.Context.NOTIFICATION_SERVICE
|
|
|
|
)
|
2021-06-05 23:39:42 +05:30
|
|
|
NotifySrv.notify(data.nID, this.getNotification(data, ctx))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
export class Printer {
|
|
|
|
static PrintPackage = global.androidx.print
|
|
|
|
static isSupported() {
|
|
|
|
return this.PrintPackage.PrintHelper.systemSupportsPrint()
|
|
|
|
}
|
|
|
|
static print(view) {
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
try {
|
|
|
|
let img: any
|
|
|
|
img = android.graphics.Bitmap.createBitmap(
|
|
|
|
view.getMeasuredWidth(),
|
|
|
|
view.getMeasuredHeight(),
|
|
|
|
android.graphics.Bitmap.Config.ARGB_8888
|
|
|
|
)
|
|
|
|
view.android.draw(new android.graphics.Canvas(img))
|
|
|
|
this.printImage(img).then(resolve, reject)
|
|
|
|
} catch (e) {
|
|
|
|
reject(e)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
static printImage(img) {
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
try {
|
|
|
|
let callback = (success) => resolve(success)
|
|
|
|
let printHelper = new this.PrintPackage.PrintHelper(
|
|
|
|
Application.android.foregroundActivity
|
|
|
|
)
|
|
|
|
printHelper.setScaleMode(this.PrintPackage.PrintHelper.SCALE_MODE_FIT)
|
|
|
|
let jobName = 'MyPrintJob'
|
|
|
|
printHelper.printBitmap(jobName, img)
|
|
|
|
callback(true)
|
|
|
|
} catch (e) {
|
|
|
|
reject(e)
|
|
|
|
}
|
|
|
|
})
|
2021-05-22 14:26:31 +05:30
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// GET RINGTONES LIST
|
|
|
|
export const getTones = () => {
|
|
|
|
const RingtoneManager = android.media.RingtoneManager
|
2021-05-25 20:02:53 +05:30
|
|
|
let ctx = Utils.ad.getApplicationContext()
|
2021-05-22 14:26:31 +05:30
|
|
|
const ringtonesMgr = new RingtoneManager(ctx)
|
|
|
|
ringtonesMgr.setType(RingtoneManager.TYPE_ALARM)
|
|
|
|
const cursor = ringtonesMgr.getCursor()
|
2021-05-25 20:02:53 +05:30
|
|
|
let tones = []
|
2021-05-22 14:26:31 +05:30
|
|
|
while (cursor.moveToNext()) {
|
|
|
|
tones.push({
|
|
|
|
title: cursor.getString(RingtoneManager.TITLE_COLUMN_INDEX),
|
|
|
|
uri:
|
|
|
|
cursor.getString(RingtoneManager.URI_COLUMN_INDEX) +
|
|
|
|
'/' +
|
|
|
|
cursor.getString(RingtoneManager.ID_COLUMN_INDEX),
|
|
|
|
})
|
|
|
|
}
|
2021-05-25 20:02:53 +05:30
|
|
|
|
|
|
|
let defaultToneUri = RingtoneManager.getActualDefaultRingtoneUri(
|
|
|
|
ctx,
|
|
|
|
RingtoneManager.TYPE_ALARM
|
|
|
|
)
|
|
|
|
let defaultTone
|
|
|
|
if (defaultToneUri) {
|
|
|
|
let uriString = defaultToneUri.toString()
|
|
|
|
let tonesAvailable = tones.filter((e) => e.uri == uriString)
|
|
|
|
let toneExist = tonesAvailable.length
|
|
|
|
defaultTone = {
|
|
|
|
title: toneExist ? tonesAvailable[0].title : tones[0].title,
|
|
|
|
uri: toneExist ? uriString : tones[0].uri,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return { tones, defaultTone: defaultToneUri ? defaultTone : tones[0] }
|
2021-05-22 14:26:31 +05:30
|
|
|
}
|
2021-06-05 23:39:42 +05:30
|
|
|
|
|
|
|
//DETECT RTL LANGUAGE
|
|
|
|
export const RTL = (): boolean => {
|
|
|
|
const ctx = Utils.android.getApplicationContext()
|
|
|
|
const config = ctx.getResources().getConfiguration()
|
|
|
|
return config.getLayoutDirection() == android.view.View.LAYOUT_DIRECTION_RTL
|
|
|
|
}
|
|
|
|
|
|
|
|
//WAKE LOCK
|
|
|
|
export const wakeLock = (bool) => {
|
|
|
|
bool ? !wl.isHeld() && wl.acquire() : wl.isHeld() && wl.release()
|
|
|
|
}
|