Files
freeplanet/src/store/Modules/tools.ts

3222 lines
79 KiB
TypeScript
Raw Normal View History

import { Todos, Projects, UserStore, CalendarStore, GlobalStore } from '@store'
2019-03-13 01:53:53 +01:00
import globalroutines from './../../globalroutines/index'
import { costanti } from './costanti'
2019-07-12 14:09:44 +02:00
import { toolsext } from './toolsext'
2019-04-05 23:59:52 +02:00
import { translation } from './translation'
import Quasar, { colors, date, Screen } from 'quasar'
import { scroll } from 'quasar'
import { copyToClipboard } from 'quasar'
const { getScrollTarget, setScrollPosition } = scroll
import {
IBookedEvent,
ICollaborations,
IEvents,
IListRoutes,
IMenuList,
IParamDialog,
IProject,
ITodo,
Privacy
} from '@src/model'
2019-03-22 20:51:42 +01:00
import * as ApiTables from '@src/store/Modules/ApiTables'
2019-04-05 23:59:52 +02:00
import translate from '@src/globalroutines/util'
import { RouteNames } from '@src/router/route-names'
import { lists } from './lists'
import { preloadedimages, static_data } from '@src/db/static_data'
import { IColl, ITimeLineEntry, ITimeLineMain } from '@src/model/GlobalStore'
2019-10-10 16:53:33 +02:00
import { func_tools } from '@src/store/Modules/toolsext'
import { serv_constants } from '@src/store/Modules/serv_constants'
import { shared_consts } from '@src/common/shared_vuejs'
import { dom } from 'quasar'
const printf = require('util').format;
const { height, width } = dom
import Cookies from 'js-cookie'
const TokenKey = 'Admin-Token'
2019-03-13 13:40:17 +01:00
export interface INotify {
color?: string | 'primary'
textColor?: string
icon?: string | ''
}
export const tools = {
CAN_EDIT: 'q-ce',
getprefCountries: ['it', 'si', 'us', 'es', 'uk', 'fr', 'de', 'ch'],
2019-12-29 23:29:56 +01:00
APORTADOR_NONE: '------',
APORTADOR_SOLIDARIO: 'apsol',
listBestColor: [
'blue',
'green',
'purple',
'deep-purple',
'indigo',
'light-blue',
'cyan',
'teal',
'lime',
'orange',
'deeporange',
'grey',
'blue-gray',
'yellow'
],
TABUSER: 'users',
TABEVENTS: 'myevents',
TABEXTRALIST: 'extralist',
TABNEWSLETTER: 'newstosent',
TABGALLERY: 'gallery',
TABMAILINGLIST: 'mailinglist',
TABMYPAGE: 'mypage',
TABCALZOOM: 'calzoom',
TABTEMPLEMAIL: 'templemail',
TABOPZEMAIL: 'opzemail',
MAX_CHARACTERS: 60,
2019-04-29 01:01:31 +02:00
projects: 'projects',
todos: 'todos',
EMPTY: 0,
CALLING: 10,
OK: 20,
ERR_GENERICO: -1,
ERR_SERVERFETCH: -2,
ERR_AUTHENTICATION: -5,
NOFIELD: 'nofield',
TYPE_AUDIO: 1,
NUMSEC_CHECKUPDATE: 20000,
FIRST_PROJ: '5ca8f17fcd40dc5012f53346',
2019-03-28 12:58:34 +01:00
2019-04-25 00:30:13 +02:00
WHAT_NOTHING: 0,
WHAT_TODO: 1,
WHAT_PROJECT: 2,
2019-07-12 18:23:16 +02:00
languageid: 5,
SERVKEY_VERS: 'vers',
localStorage: {
teleg_id: 'ti',
verified_email: 'vf',
2019-12-31 00:44:43 +01:00
made_gift: 'mg',
2019-02-13 18:48:30 +01:00
wasAlreadySubOnDb: 'sb',
categorySel: 'cs',
isLogged: 'ilog',
expirationDate: 'expdate',
leftDrawerOpen: 'ldo',
userId: 'uid',
token: 'tk',
2019-02-16 02:01:17 +01:00
username: 'uname',
2019-10-10 16:53:33 +02:00
name: 'nm',
surname: 'sn',
perm: 'pm',
lang: 'lg',
img: 'img'
},
2019-03-22 18:49:38 +01:00
Priority: {
PRIORITY_HIGH: 2,
PRIORITY_NORMAL: 1,
PRIORITY_LOW: 0
},
Status: {
NONE: 0,
OPENED: 1,
2019-04-05 23:59:52 +02:00
COMPLETED: 10
},
FieldType: {
boolean: 1,
date: 2,
string: 4,
binary: 8,
html: 16,
select: 32,
number: 64,
typeinrec: 128,
multiselect: 256,
password: 512,
listimages: 1024,
image: 2048,
2019-12-29 23:29:56 +01:00
nationality: 4096,
intcode: 5000,
multioption: 6000
},
FieldTypeArr: [
{ label: 'Boolean', value: 1 },
{ label: 'Date', value: 2 },
{ label: 'String', value: 4 },
{ label: 'Binary', value: 8 },
{ label: 'Html', value: 16 },
{ label: 'Select', value: 32 },
{ label: 'Number', value: 64 }
],
2019-10-10 16:53:33 +02:00
SelectListNumPeople: [
{
id: 1,
label: '1',
value: 1
},
{
id: 2,
label: '2',
value: 2
},
{
id: 3,
label: '3',
value: 3
},
{
id: 4,
label: '4',
value: 4
},
{
id: 5,
label: '5',
value: 5
}
]
,
2019-04-05 23:59:52 +02:00
selectPhase: {
2019-04-05 16:16:29 +02:00
it: [
{
id: 1,
2019-04-05 23:59:52 +02:00
label: translation.it.fase + ' 0',
value: 0
2019-04-05 16:16:29 +02:00
},
{
id: 2,
2019-04-05 23:59:52 +02:00
label: translation.it.fase + ' 1',
value: 1
2019-04-05 16:16:29 +02:00
},
{
2019-04-05 23:59:52 +02:00
id: 3,
label: translation.it.fase + ' 2',
value: 2
},
{
id: 4,
label: translation.it.fase + ' 3',
value: 3
2019-04-05 16:16:29 +02:00
}
],
es: [
{
id: 1,
2019-04-05 23:59:52 +02:00
label: translation.es.fase + ' 0',
value: 0
2019-04-05 16:16:29 +02:00
},
{
id: 2,
2019-04-05 23:59:52 +02:00
label: translation.es.fase + ' 1',
value: 1
2019-04-05 16:16:29 +02:00
},
{
2019-04-05 23:59:52 +02:00
id: 3,
label: translation.es.fase + ' 2',
value: 2
},
{
id: 4,
label: translation.es.fase + ' 3',
value: 3
2019-04-05 16:16:29 +02:00
}
],
enUs: [
{
id: 1,
2019-04-05 23:59:52 +02:00
label: translation.enUs.fase + ' 0',
value: 0
2019-04-05 16:16:29 +02:00
},
{
id: 2,
2019-04-05 23:59:52 +02:00
label: translation.enUs.fase + ' 1',
value: 1
2019-04-05 16:16:29 +02:00
},
{
2019-04-05 23:59:52 +02:00
id: 3,
label: translation.enUs.fase + ' 2',
value: 2
},
{
id: 4,
label: translation.enUs.fase + ' 3',
value: 3
2019-04-05 16:16:29 +02:00
}
]
},
selectPrivacy: {
it: [
{
id: 1,
label: translation.it.privacy.all,
value: Privacy.all
},
{
id: 2,
label: translation.it.privacy.friends,
value: Privacy.friends
},
{
id: 3,
label: translation.it.privacy.mygroup,
value: Privacy.mygroup
},
{
id: 4,
label: translation.it.privacy.onlyme,
value: Privacy.onlyme
}
],
es: [
{
id: 1,
label: translation.es.privacy.all,
value: Privacy.all
},
{
id: 2,
label: translation.es.privacy.friends,
value: Privacy.friends
},
{
id: 3,
label: translation.es.privacy.mygroup,
value: Privacy.mygroup
},
{
id: 4,
label: translation.es.privacy.onlyme,
value: Privacy.onlyme
}
],
enUs: [
{
id: 1,
label: translation.enUs.privacy.all,
value: Privacy.all
},
{
id: 2,
label: translation.enUs.privacy.friends,
value: Privacy.friends
},
{
id: 3,
label: translation.enUs.privacy.mygroup,
value: Privacy.mygroup
},
{
id: 4,
label: translation.enUs.privacy.onlyme,
value: Privacy.onlyme
}
]
2019-04-05 16:16:29 +02:00
},
2019-04-05 23:59:52 +02:00
selectStatus: {
2019-03-13 01:53:53 +01:00
it: [
{
id: 1,
2019-04-05 23:59:52 +02:00
label: 'Nessuno',
value: 0, // Status.NONE
icon: 'expand_less'
},
{
id: 2,
2019-04-05 23:59:52 +02:00
label: 'Aperto',
value: 1, // Status.OPENED
2019-02-16 02:01:17 +01:00
icon: 'expand_less'
},
{
id: 3,
2019-04-05 23:59:52 +02:00
label: 'Completato',
value: 10, // Status.COMPLETED
2019-02-16 02:01:17 +01:00
icon: 'expand_less'
2019-04-05 23:59:52 +02:00
}
],
es:
[
{
id: 1,
label: 'Ninguno',
value: 0, // Status.NONE
icon: 'expand_less'
},
{
id: 2,
label: 'Abierto',
value: 1, // Status.OPENED
icon: 'expand_less'
},
{
id: 3,
2019-04-05 23:59:52 +02:00
label: 'Completado',
value: 10, // Status.COMPLETED
icon: 'expand_less'
}
],
enUs:
[
{
id: 1,
label: 'None',
value: 0, // Status.NONE
icon: 'expand_less'
},
{
id: 2,
label: 'Opened',
value: 1, // Status.OPENED
icon: 'expand_less'
},
{
id: 3,
2019-04-05 23:59:52 +02:00
label: 'Completed',
value: 10, // Status.COMPLETED
icon: 'expand_less'
}
]
}
,
INDEX_MENU_DELETE: 4,
2019-04-05 23:59:52 +02:00
menuPopupTodo:
{
it: [
2019-04-29 01:01:31 +02:00
{
id: 5,
disable: false,
label: 'Taglia',
value: lists.MenuAction.CUT,
2019-04-29 01:01:31 +02:00
icon: 'undo'
},
2019-04-05 23:59:52 +02:00
{
id: 10,
2019-04-29 01:01:31 +02:00
disable: false,
2019-07-10 11:37:00 +02:00
label: 'Modifica',
value: lists.MenuAction.EDIT,
icon: 'create'
},
{
id: 11,
disable: false,
label: 'Elimina',
value: lists.MenuAction.DELETE,
icon: 'delete',
checked: false
},
{
id: 12,
disable: false,
2019-04-05 23:59:52 +02:00
label: '',
value: lists.MenuAction.PROGRESS_BAR,
2019-04-05 23:59:52 +02:00
icon: 'rowing',
checked: true
},
{
id: 20,
2019-04-29 01:01:31 +02:00
disable: false,
2019-04-05 23:59:52 +02:00
label: 'Imposta Priorità',
value: lists.MenuAction.PRIORITY,
2019-04-05 23:59:52 +02:00
icon: 'rowing',
checked: false,
arrlista: lists.selectPriority.it
},
{
id: 21,
disable: false,
label: translation.it.proj.themecolor,
value: lists.MenuAction.THEME,
icon: 'format_color_text',
checked: false,
arrlista: lists.selectTheme
},
{
id: 22,
disable: false,
label: translation.it.proj.themebgcolor,
value: lists.MenuAction.THEMEBG,
icon: 'format_color_fill',
checked: false,
arrlista: lists.selectTheme
2019-04-05 23:59:52 +02:00
},
{
id: 30,
2019-04-29 01:01:31 +02:00
disable: false,
2019-04-05 23:59:52 +02:00
label: 'Completato',
value: lists.MenuAction.COMPLETED,
2019-04-05 23:59:52 +02:00
icon: 'check_circle',
checked: true
},
{
id: 40,
2019-04-29 01:01:31 +02:00
disable: false,
2019-04-05 23:59:52 +02:00
label: 'Imposta Scadenza',
value: lists.MenuAction.TOGGLE_EXPIRING,
2019-04-05 23:59:52 +02:00
icon: 'date_range',
checked: true
}
],
es:
[
2019-04-29 01:01:31 +02:00
{
id: 5,
disable: false,
label: 'Cortar',
value: lists.MenuAction.CUT,
2019-04-29 01:01:31 +02:00
icon: 'undo'
},
2019-07-10 11:37:00 +02:00
{
id: 7,
disable: false,
label: 'Editar',
value: lists.MenuAction.EDIT,
icon: 'create'
},
{
id: 8,
disable: false,
label: 'Borrar',
value: lists.MenuAction.DELETE,
icon: 'delete',
checked: false
},
2019-04-05 23:59:52 +02:00
{
id: 10,
2019-04-29 01:01:31 +02:00
disable: false,
2019-04-05 23:59:52 +02:00
label: '',
value: lists.MenuAction.PROGRESS_BAR,
2019-04-05 23:59:52 +02:00
icon: 'rowing',
checked: true
},
{
id: 20,
2019-04-29 01:01:31 +02:00
disable: false,
2019-04-05 23:59:52 +02:00
label: 'Establecer Prioridad',
value: lists.MenuAction.PRIORITY,
2019-04-05 23:59:52 +02:00
icon: 'rowing',
checked: false,
arrlista: lists.selectPriority.es
},
{
id: 21,
disable: false,
label: translation.es.proj.themecolor,
value: lists.MenuAction.THEME,
icon: 'format_color_text',
checked: false,
arrlista: lists.selectTheme
},
{
id: 22,
disable: false,
label: translation.es.proj.themebgcolor,
value: lists.MenuAction.THEMEBG,
icon: 'format_color_fill',
checked: false,
arrlista: lists.selectTheme
2019-04-05 23:59:52 +02:00
},
{
id: 30,
2019-04-29 01:01:31 +02:00
disable: false,
2019-04-05 23:59:52 +02:00
label: 'Completado',
value: lists.MenuAction.COMPLETED,
2019-04-05 23:59:52 +02:00
icon: 'check_circle',
checked: true
},
{
id: 40,
2019-04-29 01:01:31 +02:00
disable: false,
2019-04-05 23:59:52 +02:00
label: 'Establecer expiración',
value: lists.MenuAction.TOGGLE_EXPIRING,
2019-04-05 23:59:52 +02:00
icon: 'date_range',
checked: true
}
],
enUs:
[
2019-04-29 01:01:31 +02:00
{
id: 5,
disable: false,
label: 'Cut',
value: lists.MenuAction.CUT,
2019-04-29 01:01:31 +02:00
icon: 'undo'
},
2019-07-10 11:37:00 +02:00
{
id: 7,
disable: false,
label: 'Edit',
value: lists.MenuAction.EDIT,
icon: 'create'
},
{
id: 8,
disable: false,
label: 'Delete',
value: lists.MenuAction.DELETE,
icon: 'trash',
checked: false
},
2019-04-05 23:59:52 +02:00
{
id: 10,
2019-04-29 01:01:31 +02:00
disable: false,
2019-04-05 23:59:52 +02:00
label: '',
value: lists.MenuAction.PROGRESS_BAR,
2019-04-05 23:59:52 +02:00
icon: 'check_circle',
checked: true
},
{
id: 20,
2019-04-29 01:01:31 +02:00
disable: false,
2019-04-05 23:59:52 +02:00
label: 'Set Priority',
value: lists.MenuAction.PRIORITY,
2019-04-05 23:59:52 +02:00
icon: 'high_priority',
checked: false,
arrlista: lists.selectPriority.enUs
},
{
id: 21,
disable: false,
label: translation.enUs.proj.themecolor,
value: lists.MenuAction.THEME,
icon: 'format_color_text',
checked: false,
arrlista: lists.selectTheme
},
{
id: 22,
disable: false,
label: translation.enUs.proj.themebgcolor,
value: lists.MenuAction.THEMEBG,
icon: 'format_color_fill',
checked: false,
arrlista: lists.selectTheme
2019-04-05 23:59:52 +02:00
},
{
id: 30,
2019-04-29 01:01:31 +02:00
disable: false,
2019-04-05 23:59:52 +02:00
label: 'Completed',
value: lists.MenuAction.COMPLETED,
2019-04-05 23:59:52 +02:00
icon: 'check_circle',
checked: true
},
{
id: 40,
2019-04-29 01:01:31 +02:00
disable: false,
2019-04-05 23:59:52 +02:00
label: 'Set Expiring',
value: lists.MenuAction.TOGGLE_EXPIRING,
2019-04-05 23:59:52 +02:00
icon: 'date_range',
checked: true
}
]
}
,
2019-03-28 12:58:34 +01:00
menuPopupProj: {
it: [
2019-04-27 20:12:41 +02:00
{
id: 5,
2019-04-29 01:01:31 +02:00
disable: false,
2019-04-27 20:12:41 +02:00
label: 'Taglia',
2019-07-10 11:37:00 +02:00
value: lists.MenuAction.CUT,
2019-04-27 20:12:41 +02:00
icon: 'undo'
},
{
id: 10,
2019-04-29 01:01:31 +02:00
disable: false,
label: 'Modifica',
2019-07-10 11:37:00 +02:00
value: lists.MenuAction.EDIT,
icon: 'create'
},
2019-07-10 11:37:00 +02:00
{
id: 11,
disable: false,
label: 'Elimina',
value: lists.MenuAction.DELETE,
icon: 'delete',
checked: false
},
2019-03-28 12:58:34 +01:00
{
id: 40,
2019-04-29 01:01:31 +02:00
disable: false,
2019-03-28 12:58:34 +01:00
label: 'Imposta Scadenza',
2019-07-10 11:37:00 +02:00
value: lists.MenuAction.TOGGLE_EXPIRING,
2019-03-28 12:58:34 +01:00
icon: 'date_range',
checked: true
},
{
id: 45,
disable: false,
label: translation.it.proj.themecolor,
value: lists.MenuAction.THEME,
icon: 'format_color_text',
checked: false,
arrlista: lists.selectTheme
},
{
id: 46,
disable: false,
label: translation.it.proj.themebgcolor,
value: lists.MenuAction.THEMEBG,
icon: 'format_color_fill',
checked: false,
arrlista: lists.selectTheme
2019-03-28 12:58:34 +01:00
}
],
2019-04-05 23:59:52 +02:00
es:
[
2019-04-27 20:12:41 +02:00
{
id: 5,
2019-04-29 01:01:31 +02:00
disable: false,
2019-04-27 20:12:41 +02:00
label: 'Cortar',
2019-07-10 11:37:00 +02:00
value: lists.MenuAction.CUT,
2019-04-27 20:12:41 +02:00
icon: 'undo'
},
2019-04-05 23:59:52 +02:00
{
id: 10,
2019-04-29 01:01:31 +02:00
disable: false,
2019-04-05 23:59:52 +02:00
label: 'Editar',
2019-07-10 11:37:00 +02:00
value: lists.MenuAction.EDIT,
2019-04-05 23:59:52 +02:00
icon: 'create'
},
2019-07-10 11:37:00 +02:00
{
id: 11,
disable: false,
label: 'Borrar',
value: 100, // DELETE
icon: 'delete',
checked: false
},
2019-04-05 23:59:52 +02:00
{
id: 40,
2019-04-29 01:01:31 +02:00
disable: false,
2019-04-05 23:59:52 +02:00
label: 'Establecer expiración',
2019-07-10 11:37:00 +02:00
value: lists.MenuAction.TOGGLE_EXPIRING,
2019-04-05 23:59:52 +02:00
icon: 'date_range',
checked: true
},
{
id: 45,
disable: false,
label: translation.es.proj.themecolor,
value: lists.MenuAction.THEME,
icon: 'format_color_text',
checked: false,
arrlista: lists.selectTheme
},
{
id: 46,
disable: false,
label: translation.es.proj.themebgcolor,
value: lists.MenuAction.THEMEBG,
icon: 'format_color_fill',
checked: false,
arrlista: lists.selectTheme
2019-04-05 23:59:52 +02:00
}
],
enUs:
[
2019-04-27 20:12:41 +02:00
{
id: 5,
2019-04-29 01:01:31 +02:00
disable: false,
2019-04-27 20:12:41 +02:00
label: 'Cut',
value: 71, // CUT
icon: 'undo'
},
2019-04-05 23:59:52 +02:00
{
id: 10,
2019-04-29 01:01:31 +02:00
disable: false,
2019-04-05 23:59:52 +02:00
label: 'Edit',
2019-07-10 11:37:00 +02:00
value: lists.MenuAction.EDIT,
2019-04-05 23:59:52 +02:00
icon: 'create'
},
{
id: 40,
2019-04-29 01:01:31 +02:00
disable: false,
2019-04-05 23:59:52 +02:00
label: 'Set Expiring',
value: 101, // TOGGLE_EXPIRING
icon: 'date_range',
checked: true
},
{
id: 45,
disable: false,
label: translation.enUs.proj.themecolor,
value: lists.MenuAction.THEME,
icon: 'format_color_text',
checked: false,
arrlista: lists.selectTheme
},
{
id: 46,
disable: false,
label: translation.enUs.proj.themebgcolor,
value: lists.MenuAction.THEMEBG,
icon: 'format_color_fill',
checked: false,
arrlista: lists.selectTheme
},
2019-04-05 23:59:52 +02:00
{
id: 50,
2019-04-29 01:01:31 +02:00
disable: false,
2019-04-05 23:59:52 +02:00
label: 'Delete',
value: 100, // DELETE
icon: 'trash',
checked: false
}
]
}
,
2019-03-28 12:58:34 +01:00
2019-03-04 17:28:29 +01:00
menuPopupConfigTodo: {
2019-03-13 01:53:53 +01:00
it: [
2019-03-04 17:28:29 +01:00
{
id: 10,
2019-04-29 01:01:31 +02:00
disable: false,
2019-03-04 17:28:29 +01:00
label: 'Mostra Task',
value: 150, // SHOW_TASK
2019-03-13 01:53:53 +01:00
icon: 'rowing'
}
2019-03-04 17:28:29 +01:00
],
2019-04-05 23:59:52 +02:00
es:
[
{
id: 10,
2019-04-29 01:01:31 +02:00
disable: false,
2019-04-05 23:59:52 +02:00
label: 'Mostrar Tareas',
value: 150,
icon: 'rowing'
}
],
enUs:
[
{
id: 10,
2019-04-29 01:01:31 +02:00
disable: false,
2019-04-05 23:59:52 +02:00
label: 'Show Task',
value: 150,
icon: 'rowing'
}
]
}
,
2019-03-04 17:28:29 +01:00
2019-03-28 12:58:34 +01:00
menuPopupConfigProject: {
it: [
2019-04-27 20:12:41 +02:00
{
id: 3,
disable: false,
label: translation.it.action.paste,
value: 72, // Action.PASTE
icon: 'file_copy'
},
{
id: 5,
2019-04-27 20:12:41 +02:00
disable: false,
label: translation.it.proj.newsubproj,
value: 200, // ADD_PROJECT
icon: 'next_week'
},
2019-03-28 12:58:34 +01:00
{
id: 10,
2019-04-27 20:12:41 +02:00
disable: false,
label: translation.it.task.showtask,
2019-03-28 12:58:34 +01:00
value: 150, // SHOW_TASK
icon: 'rowing'
}
],
2019-04-05 23:59:52 +02:00
es:
[
2019-04-27 20:12:41 +02:00
{
id: 3,
disable: false,
label: translation.es.action.paste,
value: 72, // Action.PASTE
icon: 'file_copy'
},
2019-04-05 23:59:52 +02:00
{
id: 5,
2019-04-27 20:12:41 +02:00
disable: false,
label: translation.es.proj.newsubproj,
2019-04-05 23:59:52 +02:00
value: 200, // ADD_PROJECT
icon: 'next_week'
},
{
id: 10,
2019-04-27 20:12:41 +02:00
disable: false,
label: translation.es.task.showtask,
2019-04-05 23:59:52 +02:00
value: 150,
icon: 'rowing'
}
],
enUs:
[
2019-04-27 20:12:41 +02:00
{
id: 3,
disable: false,
label: translation.enUs.action.paste,
value: 72, // Action.PASTE
icon: 'file_copy'
},
2019-04-05 23:59:52 +02:00
{
id: 5,
2019-04-27 20:12:41 +02:00
disable: false,
label: translation.enUs.proj.newsubproj,
2019-04-05 23:59:52 +02:00
value: 200, // ADD_PROJECT
icon: 'next_week'
},
{
id: 10,
2019-04-27 20:12:41 +02:00
disable: false,
label: translation.enUs.task.showtask,
2019-04-05 23:59:52 +02:00
value: 150,
icon: 'rowing'
}
]
},
menuPopupConfigMAINProject: {
it: [
2019-04-27 20:12:41 +02:00
{
id: 3,
disable: false,
label: translation.it.action.paste,
value: 72, // Action.PASTE
icon: 'file_copy'
},
{
id: 5,
2019-04-27 20:12:41 +02:00
disable: false,
label: translation.it.proj.newproj,
value: 200, // ADD_PROJECT
icon: 'next_week'
}
],
es:
[
2019-04-27 20:12:41 +02:00
{
id: 3,
disable: false,
label: translation.es.action.paste,
value: 72, // Action.PASTE
icon: 'file_copy'
},
{
id: 5,
2019-04-27 20:12:41 +02:00
disable: false,
label: translation.es.proj.newproj,
value: 200, // ADD_PROJECT
icon: 'next_week'
}
],
enUs:
[
2019-04-27 20:12:41 +02:00
{
id: 3,
disable: false,
label: translation.enUs.action.paste,
value: 72, // Action.PASTE
icon: 'file_copy'
},
{
id: 5,
2019-04-27 20:12:41 +02:00
disable: false,
label: translation.enUs.proj.newproj,
value: 200, // ADD_PROJECT
icon: 'next_week'
}
]
},
2019-03-28 12:58:34 +01:00
2019-03-04 17:28:29 +01:00
listOptionShowTask: {
2019-03-13 01:53:53 +01:00
it: [
2019-03-04 17:28:29 +01:00
{
id: 10,
2019-04-27 20:12:41 +02:00
disable: false,
2019-03-04 17:28:29 +01:00
label: 'Mostra gli ultimi N completati',
value: costanti.ShowTypeTask.SHOW_LAST_N_COMPLETED,
icon: 'rowing',
checked: true
},
{
id: 20,
2019-04-27 20:12:41 +02:00
disable: false,
2019-03-04 17:28:29 +01:00
label: 'Compiti da Completare',
value: costanti.ShowTypeTask.SHOW_ONLY_TOCOMPLETE,
icon: 'rowing',
checked: false
},
{
id: 30,
2019-04-27 20:12:41 +02:00
disable: false,
2019-03-04 17:28:29 +01:00
label: 'Tutti i compiti',
value: costanti.ShowTypeTask.SHOW_ALL,
icon: 'check_circle',
checked: true
}
],
2019-04-05 23:59:52 +02:00
es:
[
{
id: 10,
2019-04-27 20:12:41 +02:00
disable: false,
2019-04-05 23:59:52 +02:00
label: 'Mostrar los ultimos N completados',
value: costanti.ShowTypeTask.SHOW_LAST_N_COMPLETED,
icon: 'rowing',
checked: true
},
{
id: 20,
2019-04-27 20:12:41 +02:00
disable: false,
2019-04-05 23:59:52 +02:00
label: 'Tareas para completar',
value: costanti.ShowTypeTask.SHOW_ONLY_TOCOMPLETE,
icon: 'rowing',
checked: false
},
{
id: 30,
2019-04-27 20:12:41 +02:00
disable: false,
2019-04-05 23:59:52 +02:00
label: 'Todos las Tareas',
value: costanti.ShowTypeTask.SHOW_ALL,
icon: 'check_circle',
checked: true
}
],
enUs:
[
{
id: 10,
2019-04-27 20:12:41 +02:00
disable: false,
2019-04-05 23:59:52 +02:00
label: 'Show last N Completed',
value: costanti.ShowTypeTask.SHOW_LAST_N_COMPLETED,
icon: 'rowing',
checked: true
},
{
id: 20,
2019-04-27 20:12:41 +02:00
disable: false,
2019-04-05 23:59:52 +02:00
label: 'Task to complete',
value: costanti.ShowTypeTask.SHOW_ONLY_TOCOMPLETE,
icon: 'rowing',
checked: false
},
{
id: 30,
2019-04-27 20:12:41 +02:00
disable: false,
2019-04-05 23:59:52 +02:00
label: 'All Tasks',
value: costanti.ShowTypeTask.SHOW_ALL,
icon: 'check_circle',
checked: true
}
]
}
,
2019-03-04 17:28:29 +01:00
2019-03-22 20:51:42 +01:00
getTitlePriority(priority) {
let cl = ''
if (priority === tools.Priority.PRIORITY_HIGH) {
cl = 'high_priority'
}
else if (priority === tools.Priority.PRIORITY_NORMAL) {
cl = 'medium_priority'
}
else if (priority === tools.Priority.PRIORITY_LOW) {
cl = 'low_priority'
}
return cl + ' titlePriority'
2019-04-05 23:59:52 +02:00
}
,
2019-03-22 20:51:42 +01:00
2019-04-05 16:16:29 +02:00
getStatusListByInd(index) {
try {
2019-07-12 14:09:44 +02:00
const arr = tools.selectStatus[toolsext.getLocale()]
2019-04-05 16:16:29 +02:00
for (const rec of arr) {
if (rec.value === index) {
return rec.label
}
}
} catch (e) {
console.log('Error: ', e)
}
return ''
2019-04-05 23:59:52 +02:00
}
,
2019-04-05 16:16:29 +02:00
2019-03-22 20:51:42 +01:00
getPriorityByInd(index) {
2019-07-12 14:09:44 +02:00
// console.log('LANG in PRIOR', toolsext.getLocale())
2019-03-22 20:51:42 +01:00
try {
2019-07-12 14:09:44 +02:00
const arr = lists.selectPriority[toolsext.getLocale()]
2019-03-22 20:51:42 +01:00
for (const rec of arr) {
if (rec.value === index) {
return rec.label
}
}
} catch (e) {
console.log('Error: ', e)
}
return ''
2019-04-05 23:59:52 +02:00
}
,
2019-03-22 20:51:42 +01:00
logelem(mystr, elem) {
console.log(mystr, 'elem [', elem._id, '] ', elem.descr, ' Pr(', tools.getPriorityByInd(elem.priority), ') [', elem.id_prev, '] modif=', elem.modified)
2019-04-05 23:59:52 +02:00
}
,
2019-03-22 20:51:42 +01:00
getelemprojstr(elem) {
return 'elem [id= ' + elem._id + '] ' + elem.descr + ' [id_prev= ' + elem.id_prev + '] '
2019-04-05 23:59:52 +02:00
}
,
logga_arrproj(myarr: IProject[]) {
let mystr = '\n'
myarr.forEach((item) => {
mystr += tools.getelemprojstr(item) + ' '
})
return mystr
2019-04-05 23:59:52 +02:00
}
,
logelemprj(mystr, elem) {
console.log(mystr, tools.getelemprojstr(elem))
2019-04-05 23:59:52 +02:00
}
,
2019-03-22 20:51:42 +01:00
getstrelem(elem) {
return 'elem [' + elem._id + '] ' + elem.descr + ' Pr(' + tools.getPriorityByInd(elem.priority) + ') [ID_PREV=' + elem.id_prev + '] modif=' + elem.modified + ' '
2019-04-05 23:59:52 +02:00
}
,
2019-03-22 20:51:42 +01:00
2019-04-05 23:59:52 +02:00
logga_arr(myarr
:
ITodo[]
) {
2019-03-22 20:51:42 +01:00
let mystr = '\n'
myarr.forEach((item) => {
mystr += '[' + item.pos + '] ' + item.descr + ' Pr(' + tools.getPriorityByInd(item.priority) + ') [' + item.id_prev + '] modif=' + item.modified + '\n'
// mystr += '[' + item.pos + '] ' + item.descr + '\n'
})
return mystr
2019-04-05 23:59:52 +02:00
}
,
2019-03-22 20:51:42 +01:00
touchmove(scrollable) {
if (window) {
window.addEventListener('touchmove', (e) => {
// console.log('touchmove')
if (!scrollable) {
e.preventDefault()
}
}, { passive: false })
}
2019-04-05 23:59:52 +02:00
}
,
2019-03-22 20:51:42 +01:00
jsonCopy(src) {
return JSON.parse(JSON.stringify(src))
2019-04-05 23:59:52 +02:00
}
,
getItemLS(item) {
let ris = localStorage.getItem(item)
2019-03-13 01:53:53 +01:00
if ((ris == null) || (ris === '') || (ris === 'null')) {
ris = ''
2019-03-13 01:53:53 +01:00
}
return ris
2019-04-05 23:59:52 +02:00
}
,
notifyarraychanged(array) {
2019-03-13 01:53:53 +01:00
if (array.length > 0) {
array.splice(array.length - 1, 1, array[array.length - 1])
2019-03-13 01:53:53 +01:00
}
2019-04-05 23:59:52 +02:00
}
,
2019-03-22 20:51:42 +01:00
isOkIndex(myarr, index) {
return (index >= 0 && index < myarr.length)
2019-04-05 23:59:52 +02:00
}
,
2019-03-22 20:51:42 +01:00
update_idprev(myarr, indelemchange, indelemId) {
if (tools.isOkIndex(myarr, indelemchange)) {
2019-03-22 20:51:42 +01:00
const id_prev = (indelemId >= 0) ? myarr[indelemId]._id : ApiTables.LIST_START
console.log('update_idprev [', indelemchange, ']', '[id_prev=', id_prev, ']')
2019-03-22 20:51:42 +01:00
if (myarr[indelemchange].id_prev !== id_prev) {
// tools.notifyarraychanged(myarr)
2019-03-22 20:51:42 +01:00
// myarr[indelemchange].modified = true
// console.log('update_idprev Index=', indelemchange, 'indtoget', indelemId, tools.getstrelem(myarr[indelemchange]))
console.log(' MODIFICATO! ', myarr[indelemchange].descr, ' PRIMA:', myarr[indelemchange].id_prev, 'DOPO: ', id_prev)
myarr[indelemchange].id_prev = id_prev
2019-03-22 20:51:42 +01:00
return myarr[indelemchange]
}
}
return null
2019-04-05 23:59:52 +02:00
}
,
2019-03-22 20:51:42 +01:00
2019-04-05 23:59:52 +02:00
async swapGeneralElem(nametable, myarr, itemdragend, listFieldsToChange) {
2019-03-22 20:51:42 +01:00
if (itemdragend.field === 'priority') {
// get last elem priority
console.log('get last elem priority')
itemdragend.newIndex = tools.getLastFirstElemPriority(myarr, itemdragend.prioritychosen, itemdragend.atfirst, itemdragend.idelemtochange)
itemdragend.oldIndex = tools.getIndexById(myarr, itemdragend.idelemtochange)
2019-03-22 20:51:42 +01:00
console.log('swapElems PRIORITY', itemdragend)
}
if (itemdragend.newIndex === itemdragend.oldIndex) {
2019-03-28 12:58:34 +01:00
return
}
2019-03-28 12:58:34 +01:00
console.log('swapGeneralElem', 'new =', itemdragend.newIndex, 'Old =', itemdragend.oldIndex, itemdragend)
2019-03-22 20:51:42 +01:00
if (tools.isOkIndex(myarr, itemdragend.newIndex) && tools.isOkIndex(myarr, itemdragend.oldIndex)) {
console.log('*** SPLICE!')
// console.log(' PRIMA!', tools.logga_arrproj(myarr))
2019-03-22 20:51:42 +01:00
myarr.splice(itemdragend.newIndex, 0, myarr.splice(itemdragend.oldIndex, 1)[0])
// console.log(' DOPO!', tools.logga_arrproj(myarr))
2019-03-22 20:51:42 +01:00
// Ora inverti gli indici
const indold = itemdragend.oldIndex
itemdragend.oldIndex = itemdragend.newIndex
itemdragend.newIndex = indold
if (nametable === 'todos') {
if (itemdragend.field !== 'priority') {
const precind = itemdragend.newIndex - 1
const nextind = itemdragend.newIndex + 1
if (tools.isOkIndex(myarr, precind) && tools.isOkIndex(myarr, nextind)) {
if ((myarr[precind].priority === myarr[nextind].priority) && (myarr[precind].priority !== myarr[itemdragend.newIndex].priority)) {
console.log(' 1)')
2019-03-22 20:51:42 +01:00
myarr[itemdragend.newIndex].priority = myarr[precind].priority
tools.notifyarraychanged(myarr)
}
} else {
if (!tools.isOkIndex(myarr, precind)) {
if ((myarr[nextind].priority !== myarr[itemdragend.newIndex].priority)) {
console.log(' 2)')
myarr[itemdragend.newIndex].priority = myarr[nextind].priority
tools.notifyarraychanged(myarr)
}
} else {
if ((myarr[precind].priority !== myarr[itemdragend.newIndex].priority)) {
console.log(' 3)')
myarr[itemdragend.newIndex].priority = myarr[precind].priority
tools.notifyarraychanged(myarr)
}
2019-03-22 20:51:42 +01:00
}
}
2019-03-22 20:51:42 +01:00
}
}
// Update the id_prev property
const elem1 = tools.update_idprev(myarr, itemdragend.newIndex, itemdragend.newIndex - 1) // 0, -1
const elem2 = tools.update_idprev(myarr, itemdragend.newIndex + 1, itemdragend.newIndex) // 1, 0
const elem3 = tools.update_idprev(myarr, itemdragend.oldIndex, itemdragend.oldIndex - 1) // 1, 0
const elem4 = tools.update_idprev(myarr, itemdragend.oldIndex + 1, itemdragend.oldIndex) // 2, 1
2019-03-22 20:51:42 +01:00
2019-04-05 23:59:52 +02:00
await
ApiTables.table_ModifyRecord(nametable, elem1, listFieldsToChange, 'id_prev')
await
ApiTables.table_ModifyRecord(nametable, elem2, listFieldsToChange, 'id_prev')
await
ApiTables.table_ModifyRecord(nametable, elem3, listFieldsToChange, 'id_prev')
await
ApiTables.table_ModifyRecord(nametable, elem4, listFieldsToChange, 'id_prev')
tools.notifyarraychanged(myarr)
console.log('arr FINALE', tools.logga_arrproj(myarr))
2019-03-22 20:51:42 +01:00
// Update the records:
}
2019-04-05 23:59:52 +02:00
}
,
2019-03-22 20:51:42 +01:00
getIndexById(myarr, id) {
if (myarr === undefined)
return -1
2019-03-28 12:58:34 +01:00
return myarr.indexOf(tools.getElemById(myarr, id))
2019-04-05 23:59:52 +02:00
}
,
2019-03-22 20:51:42 +01:00
getElemById(myarr, id) {
if (myarr === undefined)
return null
// console.log('getElemById', myarr, id)
2019-03-22 20:51:42 +01:00
return myarr.find((elem) => elem._id === id)
2019-04-05 23:59:52 +02:00
}
,
2019-03-22 20:51:42 +01:00
getElemPrevById(myarr, id) {
if (myarr === undefined)
return null
2019-03-22 20:51:42 +01:00
return myarr.find((elem) => elem.id_prev === id)
2019-04-05 23:59:52 +02:00
}
,
getLastFirstElemPriority(myarr, priority: number, atfirst: boolean, escludiId: string) {
2019-03-22 20:51:42 +01:00
if (myarr === null) {
return -1
}
let trovato: boolean = false
console.log('priority', priority)
for (let indrec = 0; indrec < myarr.length; indrec++) {
if ((myarr[indrec].priority === priority) && (myarr[indrec]._id !== escludiId)) {
trovato = true
if (atfirst) {
return indrec - 1
}
} else {
if (trovato) {
return indrec
}
}
}
console.log('trovato?', trovato, 'indrec')
if (trovato) {
return myarr.length - 1
} else {
if (priority === tools.Priority.PRIORITY_LOW) {
return myarr.length - 1
}
else if (priority === tools.Priority.PRIORITY_HIGH) {
return 0
}
}
2019-04-05 23:59:52 +02:00
}
,
2019-03-22 20:51:42 +01:00
getFirstList(myarr) {
return myarr.find((elem) => elem.id_prev === ApiTables.LIST_START)
2019-04-05 23:59:52 +02:00
}
,
2019-03-22 20:51:42 +01:00
2019-03-28 12:58:34 +01:00
getModulesByTable(nametable) {
2019-03-22 20:51:42 +01:00
if (nametable === 'todos') {
2019-03-28 12:58:34 +01:00
return Todos
2019-03-22 20:51:42 +01:00
} else if (nametable === 'projects') {
2019-03-28 12:58:34 +01:00
return Projects
2019-03-22 20:51:42 +01:00
}
2019-04-05 23:59:52 +02:00
}
,
2019-03-28 12:58:34 +01:00
setArrayMainByTable(nametable, myarr) {
if (nametable === 'todos') {
Todos.state.todos = tools.jsonCopy(myarr)
return Todos.state.todos
} else if (nametable === 'projects') {
Projects.state.projects = tools.jsonCopy(myarr)
return Projects.state.projects
}
2019-04-05 23:59:52 +02:00
}
,
getmyid(id) {
return 'row' + id
2019-04-05 23:59:52 +02:00
}
,
getLastListNotCompleted(nametable, cat, tipoproj: string) {
2019-07-10 11:37:00 +02:00
// console.log('getLastListNotCompleted')
// const module = tools.getModulesByTable(nametable)
let arr = []
if (nametable === 'projects')
arr = Projects.getters.projs_dacompletare(cat, tipoproj)
else if (nametable === 'todos')
arr = Todos.getters.items_dacompletare(cat)
2019-03-22 20:51:42 +01:00
if (!!arr)
return (arr.length > 0) ? arr[arr.length - 1] : null
else
return null
},
2019-03-22 20:51:42 +01:00
getElemByIndex(myarr, index) {
if (index >= 0 && index < myarr.length) {
return myarr[index]
}
else {
return null
}
2019-04-05 23:59:52 +02:00
}
,
2019-03-22 20:51:42 +01:00
existArr(x) {
return x = (typeof x !== 'undefined' && x instanceof Array) ? x : []
2019-04-05 23:59:52 +02:00
}
,
json2array(json) {
2019-03-13 01:53:53 +01:00
const result = []
const keys = Object.keys(json)
keys.forEach((key) => {
result.push(json[key])
})
return result
2019-10-10 16:53:33 +02:00
},
visumenu(elem) { // : IListRoutes
2019-12-31 00:44:43 +01:00
let visu = ((elem.onlyAdmin && UserStore.state.isAdmin) || (elem.onlyManager && UserStore.state.isManager)
|| ((!elem.onlyAdmin) && (!elem.onlyManager))) && elem.active
if (!tools.isLoggedToSystem()) {
if (elem.onlyif_logged)
visu = false
}
2019-12-31 00:44:43 +01:00
if (elem.meta && elem.meta.requiresAuth) {
visu = visu && tools.isLoggedToSystem()
}
return visu
},
executefunc(myself: any, table, func: number, par: IParamDialog) {
if (func === lists.MenuAction.DELETE) {
console.log('param1', par.param1)
CalendarStore.actions.CancelBookingEvent({
ideventbook: par.param1,
notify: par.param2 === true ? '1' : '0'
}).then((ris) => {
if (ris) {
tools.showPositiveNotif(myself.$q, myself.$t('cal.canceledbooking') + ' "' + par.param3 + '"')
if (myself.bookEventpage)
myself.bookEventpage.show = false
} else
2019-10-10 16:53:33 +02:00
tools.showNegativeNotif(myself.$q, myself.$t('cal.cancelederrorbooking'))
})
} else if (func === lists.MenuAction.DELETE_EVENT) {
console.log('param1', par.param1, 'id', par.param1._id)
CalendarStore.actions.CancelEvent({ id: par.param1._id }).then((ris) => {
if (ris) {
// Remove this record from my list
CalendarStore.state.eventlist = CalendarStore.state.eventlist.filter((event) => (event._id !== par.param1._id))
tools.showPositiveNotif(myself.$q, myself.$t('cal.canceledevent') + ' "' + par.param1.title + '"')
} else
tools.showNegativeNotif(myself.$q, myself.$t('cal.cancelederrorevent'))
})
} else if (func === lists.MenuAction.DELETE_EXTRALIST) {
// console.log('param1', par.param1, 'id', par.param1._id)
GlobalStore.actions.DeleteRec({ table: tools.TABEXTRALIST, id: par.param1._id }).then((ris) => {
if (ris) {
myself.update_username()
tools.showPositiveNotif(myself.$q, myself.$t('reg.cancella_invitato') + ' "' + par.param1.name + ' ' + par.param1.surname + '"')
} else
tools.showNegativeNotif(myself.$q, myself.$t('db.recfailed'))
})
} else if (func === lists.MenuAction.REGALA_INVITATO) {
// console.log('param1', par.param1, 'id', par.param1._id)
const mydatatosave = {
id: par.param1._id,
table: tools.TABUSER,
fieldsvalue: { aportador_solidario: par.param2 },
notifBot: {}
}
if (par.param3) {
mydatatosave.notifBot = { un: par.param2, txt: par.param3 }
}
GlobalStore.actions.saveFieldValue(mydatatosave).then((ris) => {
if (ris) {
myself.update_username()
tools.showPositiveNotif(myself.$q, myself.$t('reg.invitato_regalato') + ' "' + par.param1.name + ' ' + par.param1.surname + '"')
} else
tools.showNegativeNotif(myself.$q, myself.$t('db.recfailed'))
})
} else if (func === lists.MenuAction.DELETE_RECTABLE) {
console.log('param1', par.param1)
GlobalStore.actions.DeleteRec({ table, id: par.param1 }).then((ris) => {
if (ris) {
myself.ActionAfterYes(func, par.param2, null)
tools.showPositiveNotif(myself.$q, myself.$t('db.deletedrecord'))
} else
tools.showNegativeNotif(myself.$q, myself.$t('db.recdelfailed'))
})
} else if (func === lists.MenuAction.DUPLICATE_RECTABLE) {
console.log('param1', par.param1)
GlobalStore.actions.DuplicateRec({ table, id: par.param1 }).then((ris) => {
if (ris) {
myself.ActionAfterYes(func, par.param2, ris.data)
tools.showPositiveNotif(myself.$q, myself.$t('db.duplicatedrecord'))
} else
tools.showNegativeNotif(myself.$q, myself.$t('db.recdupfailed'))
})
2019-10-10 16:53:33 +02:00
}
},
async askConfirm($q: any, mytitle, mytext, ok, cancel, myself: any, table, funcok: number, funccancel: number, par: IParamDialog) {
2019-10-10 16:53:33 +02:00
return $q.dialog({
message: mytext,
ok: {
label: ok,
push: true
},
title: mytitle,
cancel: true,
persistent: false
}).onOk(() => {
// console.log('OK')
tools.executefunc(myself, table, funcok, par)
2019-10-10 16:53:33 +02:00
return true
}).onCancel(() => {
// console.log('CANCEL')
tools.executefunc(myself, table, funccancel, par)
2019-10-10 16:53:33 +02:00
return false
})
},
showPositiveNotif(q: any, msg) {
tools.showNotif(q, msg, { color: 'positive', icon: 'notifications' })
},
showNegativeNotif(q: any, msg) {
tools.showNotif(q, msg, { color: 'negative', icon: 'notifications' }, 8000)
2019-10-10 16:53:33 +02:00
},
showNeutralNotif(q: any, msg) {
tools.showNotif(q, msg, { color: 'info', icon: 'notifications' })
},
showNotif(q: any, msg, data ?: INotify | null, time?) {
2019-03-13 13:40:17 +01:00
let myicon = data ? data.icon : 'ion-add'
if (!myicon) {
2019-03-13 13:40:17 +01:00
myicon = 'ion-add'
}
2019-03-13 13:40:17 +01:00
let mycolor = data ? data.color : 'primary'
if (!mycolor) {
2019-03-13 13:40:17 +01:00
mycolor = 'primary'
}
2019-03-13 13:40:17 +01:00
q.notify({
message: msg,
icon: myicon,
classes: 'my-notif-class',
color: mycolor,
timeout: time || 4000
2019-03-13 13:40:17 +01:00
})
2019-04-05 23:59:52 +02:00
}
,
2019-03-22 20:51:42 +01:00
isRegistered() {
return localStorage.getItem(tools.localStorage.userId) !== ''
2019-04-05 23:59:52 +02:00
}
,
2019-03-22 20:51:42 +01:00
checkIfUserExist(mythis) {
2019-10-10 16:53:33 +02:00
if (UserStore.getters.isUserInvalid) {
2019-03-22 20:51:42 +01:00
tools.showNotif(mythis.$q, mythis.$t('todo.usernotdefined'))
return false
}
if (!tools.isRegistered()) {
// Not logged
tools.showNotif(mythis.$q, mythis.$t('user.notregistered'))
return false
}
return true
2019-04-05 23:59:52 +02:00
}
,
2019-03-22 20:51:42 +01:00
checkLangPassed(mylang) {
// console.log('checkLangPassed')
const mybrowserLang = Quasar.lang.isoName
if (mylang !== '') {
if ((mylang.toLowerCase() === 'enus') || (mylang.toLowerCase() === 'en-us')) {
mylang = 'enUs'
}
if ((mylang.toLowerCase() === 'es') || (mylang.toLowerCase() === 'es-es') || (mylang.toLowerCase() === 'eses')) {
mylang = 'es'
}
if ((mylang.toLowerCase() === 'fr') || (mylang.toLowerCase() === 'fr-fr') || (mylang.toLowerCase() === 'frfr')) {
mylang = 'fr'
}
if ((mylang.toLowerCase() === 'it') || (mylang.toLowerCase() === 'it-it') || (mylang.toLowerCase() === 'itit')) {
mylang = 'it'
}
if (!(static_data.arrLangUsed.includes(mylang))) {
console.log('non incluso ', mylang)
mylang = static_data.arrLangUsed[0]
2019-10-10 16:53:33 +02:00
// Metti come default
UserStore.mutations.setlang(mylang)
}
}
if (!mylang) {
mylang = process.env.LANG_DEFAULT
}
2019-07-12 14:09:44 +02:00
if (toolsext.getLocale(true) === '') {
UserStore.mutations.setlang(mylang)
}
// console.log('mylang calc : ', mylang)
return mylang
2019-07-12 14:09:44 +02:00
},
getimglogo() {
return 'statics/images/' + process.env.LOGO_REG
2019-04-05 23:59:52 +02:00
}
,
consolelogpao(strlog, strlog2 = '', strlog3 = '') {
globalroutines(null, 'log', strlog + ' ' + strlog2 + ' ' + strlog3, null)
2019-04-05 23:59:52 +02:00
}
,
2019-03-22 20:51:42 +01:00
/*
get todos_vista() {
let mystr = ''
2019-03-28 12:58:34 +01:00
const arr = Todos.getters.items_dacompletare(this.categoryAtt)
2019-03-22 20:51:42 +01:00
for (const ind in arr) {
mystr += this.getstrelem(arr[ind]) + '\n'
}
return mystr + ''
}
2019-04-05 23:59:52 +02:00
*/
2019-03-22 20:51:42 +01:00
/*
public getArrTodos() {
let mystr = ''
return globalroutines(null, 'readall', 'todos', null)
.then((alldata) => {
const myrecs = [...alldata]
myrecs.forEach((rec) => {
mystr = mystr + rec.descr + rec.completed + '] ['
})
// this.tmpstrTodos = 'TODOS: ' + mystr
})
}
*/
2019-03-22 15:32:32 +01:00
aspettansec(numsec) {
return new Promise((resolve, reject) => {
2019-03-22 15:32:32 +01:00
setTimeout(() => {
resolve('anything')
}, numsec)
})
2019-04-05 23:59:52 +02:00
}
,
2019-03-22 18:49:38 +01:00
dragula_option($service, dragname) {
$service.options(dragname,
{
moves(el, source, handle, sibling) {
return !el.classList.contains('donotdrag') // elements are always draggable by default
},
accepts(el, target, source, sibling) {
return true // elements can be dropped in any of the `containers` by default
},
invalid(el, handle) {
return el.classList.contains('donotdrag') // don't prevent any drags from initiating by default
},
direction: 'vertical'
})
2019-04-05 23:59:52 +02:00
}
,
2019-03-22 18:49:38 +01:00
2019-04-05 23:59:52 +02:00
// _.cloneDeep( Per clonare un oggetto
2019-03-22 20:51:42 +01:00
isLoggedToSystem() {
const tok = tools.getItemLS(tools.localStorage.token)
return !!tok
2019-04-05 23:59:52 +02:00
}
,
mapSort(linkedList) {
2019-07-10 11:37:00 +02:00
console.log('mapSort')
let sortedList = []
const map = new Map()
let currentId = null
// console.log('linkedList', linkedList)
// index the linked list by previous_item_id
for (let i = 0; i < linkedList.length; i++) {
const item = linkedList[i]
// tools.logelemprj(i, item)
if (item.id_prev === ApiTables.LIST_START) {
// first item
currentId = String(item._id)
// console.log('currentId', currentId);
sortedList.push(item)
} else {
map.set(item.id_prev, i)
}
}
// let i2 = 0
while (sortedList.length < linkedList.length) {
// get the item with a previous item ID referencing the current item
const nextItem = linkedList[map.get(currentId)]
if (nextItem === undefined) {
break
}
sortedList.push(nextItem)
// tools.logelemprj('FATTO:' + i, nextItem)
currentId = String(nextItem._id)
// i2++
}
if (sortedList.length < linkedList.length) {
console.log('!!!!! NON CI SONO TUTTI !!!!!', sortedList.length, linkedList.length)
// Forget something not in a List !
for (const itemlinked of linkedList) {
const elemtrov = sortedList.find((item) => item._id === itemlinked._id)
if (elemtrov === undefined) {
sortedList.push(itemlinked)
}
}
}
2019-07-10 11:37:00 +02:00
// Now Order by Priority
if (!!sortedList) {
if (sortedList.length > 0) {
if (sortedList[0].priority !== undefined) {
const sortednew = []
let myarr = []
for (const priorelem of lists.selectPriority.it) {
const myprior = priorelem.value
myarr = sortedList.filter((item) => item.priority === myprior)
if (myarr !== undefined)
sortednew.push(...myarr)
}
sortedList = sortednew
}
}
}
// console.log('DOPO sortedList', sortedList)
return sortedList
2019-07-10 11:37:00 +02:00
},
getProgressClassColor(progress) {
if (progress > 66) {
return 'highperc'
} else if (progress > 33) {
return 'medperc'
} else {
return 'lowperc'
}
2019-04-05 23:59:52 +02:00
}
,
getProgressColor(progress) {
if (progress > 66) {
return 'green'
} else if (progress > 33) {
return 'blue'
} else {
return 'red'
}
},
hasManyDays(mydatestart, mydateend) {
if (mydateend)
return tools.getstrDate(mydatestart) !== tools.getstrDate(mydateend)
else
return false
},
isManager() {
return UserStore.state.isManager
},
getstrDate(mytimestamp) {
// console.log('getstrDate', mytimestamp)
2019-04-05 16:16:29 +02:00
if (!!mytimestamp)
return date.formatDate(mytimestamp, 'DD/MM/YYYY')
else
return ''
},
getstrTime(mytimestamp) {
// console.log('getstrDate', mytimestamp)
if (!!mytimestamp)
return date.formatDate(mytimestamp, 'HH:mm')
else
return ''
},
getstrShortDate(mydate) {
const DateFormatter = new Intl.DateTimeFormat(func_tools.getLocale() || void 0, {
weekday: 'long',
day: 'numeric',
month: 'short',
year: 'numeric'
// timeZone: 'UTC'
})
try {
if (DateFormatter) {
const date1 = new Date(mydate)
return DateFormatter.format(date1)
}
return mydate
} catch (e) {
return ''
}
},
getstrVeryShortDate(mydate) {
const DateFormatter = new Intl.DateTimeFormat(func_tools.getLocale() || void 0, {
weekday: 'short',
day: 'numeric',
month: 'short',
// timeZone: 'UTC'
})
try {
if (DateFormatter) {
const date1 = new Date(mydate)
return DateFormatter.format(date1)
}
return mydate
} catch (e) {
return ''
}
},
getstrVeryVeryShortDate(mydate) {
const DateFormatter = new Intl.DateTimeFormat(func_tools.getLocale() || void 0, {
weekday: 'long',
day: 'numeric',
// timeZone: 'UTC'
})
try {
if (DateFormatter) {
const date1 = new Date(mydate)
return DateFormatter.format(date1)
}
return mydate
} catch (e) {
return ''
}
},
getstrDateTimeEvent(mythis, myevent, withhtml) {
let mystr = ''
// is same day?
if (tools.getstrDate(myevent.dateTimeStart) === tools.getstrDate(myevent.dateTimeEnd)) {
if (withhtml) {
mystr += `<span class="cal__where-content">${tools.getstrDate(myevent.dateTimeStart)}</span>
<span class="cal__hours-content">${mythis.$t('cal.starttime')} ${ tools.getstrTime(myevent.dateTimeStart) }
${ mythis.$t('cal.endtime')} ${ tools.getstrTime(myevent.dateTimeEnd) }`
} else {
mystr = `${tools.getstrDate(myevent.dateTimeStart)}
${mythis.$t('cal.starttime')} ${ tools.getstrTime(myevent.dateTimeStart) }
${ mythis.$t('cal.endtime')} ${ tools.getstrTime(myevent.dateTimeEnd) }`
}
} else {
mystr = `<span class="cal__where-content">${tools.getstrDate(myevent.dateTimeStart)}</span>
<span class="cal__hours-content">${mythis.$t('cal.starttime')} ${ tools.getstrTime(myevent.dateTimeStart) } </span>
${ mythis.$t('cal.enddate')} ${tools.getstrDate(myevent.dateTimeEnd)}
<span class="cal__hours-content">${ mythis.$t('cal.endtime')} ${ tools.getstrTime(myevent.dateTimeEnd) } </span>`
}
if (myevent.infoextra) {
mystr += `<span class="cal__hours">
<span class="cal__hours-title">${mythis.$t('cal.hours')}: </span>
<span class="cal__hours-content">${ myevent.infoextra } </span>
</span>
</span>`
}
return mystr
},
getstrDateTimeEventSimple(mythis, myevent) {
let mystr = ''
// is same day?
if (tools.getstrShortDate(myevent.dateTimeStart) === tools.getstrShortDate(myevent.dateTimeEnd)) {
mystr = `${tools.getstrShortDate(myevent.dateTimeStart)}
- ${ tools.getstrTime(myevent.dateTimeStart) }`
} else {
mystr = `${tools.getstrVeryVeryShortDate(myevent.dateTimeStart)} - ${ tools.getstrShortDate(myevent.dateTimeEnd) }`
}
return mystr
},
getstrDateTimeEventShort(mythis, myevent) {
let mystr = ''
// is same day?
if (tools.getstrShortDate(myevent.dateTimeStart) === tools.getstrShortDate(myevent.dateTimeEnd)) {
mystr = `${tools.getstrVeryShortDate(myevent.dateTimeStart)}
h. ${ tools.getstrTime(myevent.dateTimeStart) }`
} else {
mystr = `${tools.getstrVeryShortDate(myevent.dateTimeStart)} - ${ tools.getstrVeryShortDate(myevent.dateTimeEnd) }`
}
return mystr
},
getstrDateTime(mytimestamp) {
// console.log('getstrDate', mytimestamp)
if (!!mytimestamp)
return date.formatDate(mytimestamp, 'DD/MM/YYYY HH:mm')
else
return ''
},
getstrDateTimeAll(mytimestamp) {
// console.log('getstrDate', mytimestamp)
if (!!mytimestamp)
return date.formatDate(mytimestamp, 'DD/MM/YYYY HH:mm:ss')
else
return ''
},
getstrTimeAll(mytimestamp) {
// console.log('getstrDate', mytimestamp)
if (!!mytimestamp)
return date.formatDate(mytimestamp, 'HH:mm:ss')
else
return ''
},
getstrDateTimeShort(mytimestamp) {
// console.log('getstrDate', mytimestamp)
if (!!mytimestamp)
return date.formatDate(mytimestamp, 'DD/MM HH:mm')
else
return ''
},
getstrDateMonthTimeShort(mytimestamp) {
// console.log('getstrDate', mytimestamp)
if (!!mytimestamp)
return date.formatDate(mytimestamp, 'DD MMM HH:mm')
else
return ''
},
getstrDateEmailTime(mythis, mytimestamp) {
// console.log('getstrDate', mytimestamp)
if (!!mytimestamp)
return date.formatDate(mytimestamp, 'DD/MM/YYYY') + ' ' + mythis.$t('cal.starttime') + ' ' + date.formatDate(mytimestamp, 'HH:mm')
else
return ''
}
,
getstrMMMDate(mytimestamp) {
// console.log('getstrDate', mytimestamp)
if (!!mytimestamp)
return date.formatDate(mytimestamp, 'DD MMM YYYY')
else
return ''
}
,
2019-04-05 16:16:29 +02:00
getstrYYMMDDDate(mytimestamp) {
return date.formatDate(mytimestamp, 'YYYY-MM-DD')
}
,
getstrYYMMDDDateTime(mytimestamp) {
return date.formatDate(mytimestamp, 'YYYY-MM-DD HH:mm')
},
getstrYYMMDDDateTimeAll(mytimestamp) {
return date.formatDate(mytimestamp, 'YYYY-MM-DD HH:mm:ss')
},
2019-04-05 16:16:29 +02:00
2019-04-05 23:59:52 +02:00
// mystrdate "26.04.2013"
convertstrtoDate(mystrdate: string) {
2019-04-05 16:16:29 +02:00
if (mystrdate.length < 10) {
return null
}
const pattern = /(\d{2})\/(\d{2})\/(\d{4})/
const strdate = mystrdate.replace(pattern, '$3-$2-$1')
let mydate = null
if (date.isValid(strdate)) {
mydate = new Date(strdate)
} else {
return null
}
// console.log('mystrdate', mystrdate, strdate, mydate)
2019-04-05 16:16:29 +02:00
return mydate
2019-04-05 23:59:52 +02:00
}
,
capitalize(value) {
if (!value) {
return ''
}
value = value.toString()
return value.charAt(0).toUpperCase() + value.slice(1)
}
,
2019-04-05 16:16:29 +02:00
2019-07-10 11:37:00 +02:00
firstchars(value, numchars = 200) {
if (!value) {
return ''
}
try {
let mycar = value.substring(0, numchars)
if (value.length > numchars)
mycar += '...'
return mycar
} catch (e) {
return value
}
}
,
2019-07-10 11:37:00 +02:00
firstchars_onedot(value, numchars = 200) {
if (!value) {
return ''
}
try {
let mycar = value.substring(0, numchars)
if (value.length > numchars)
mycar += '.'
return mycar
} catch (e) {
return value
}
}
,
2019-04-05 16:16:29 +02:00
getDateNow() {
const mydate = new Date()
return mydate
},
getDateNowEvent() {
return tools.addDays(tools.getDateNow(), -1)
},
2019-04-05 16:16:29 +02:00
getDateNull() {
2019-04-05 23:59:52 +02:00
return new Date(0)
}
,
2019-04-05 16:16:29 +02:00
getTimeNow() {
return new Date().getTime()
2019-04-05 23:59:52 +02:00
}
,
2019-04-05 16:16:29 +02:00
getTimestampsNow() {
return new Date().valueOf()
},
gettimestampByDate(mydate) {
return mydate.toString()
},
isMainProject(idproj) {
return idproj === process.env.PROJECT_ID_MAIN
}
,
getUrlByTipoProj(tipoproj, name ?: string) {
2019-04-25 00:30:13 +02:00
if (!!name)
return '/' + name + '/'
else
return '/' + tipoproj + '/'
}
,
2019-04-25 00:30:13 +02:00
// convertMenuListInListRoutes(arrlista: IMenuList[]) {
// const lista = []
// if (arrlista === undefined)
// return lista
// for (const elem of arrlista) {
// const item: IListRoutes = {
// faIcon: 'fa fa-list-alt',
// materialIcon: elem.icon,
// name: elem.nametranslate,
// text: elem.description,
// path: tools.getUrlByTipoProj(false, elem.urlroute) + elem.idelem,
// routes2: tools.convertMenuListInListRoutes(elem.routes2),
// level_parent: elem.level_parent,
// level_child: elem.level_child
//
// }
// lista.push(item)
// }
// return lista
// },
getprivacyreadbytipoproj(tipoproj) {
if (tipoproj === RouteNames.myprojects)
return Privacy.onlyme
else
return Privacy.all
}
,
getprivacywritebytipoproj(tipoproj) {
return Privacy.onlyme
}
,
2019-05-02 16:58:36 +02:00
addRoute(myarr, values) {
myarr.push(values)
}
,
displayConfirmNotification() {
let options = null
if ('serviceWorker' in navigator) {
options = {
body: 'You successfully subscribed to our Notification service!',
icon: '/statics/icons/app-icon-96x96.png',
image: '/statics/images/sf-boat.jpg',
dir: 'ltr',
lang: 'enUs', // BCP 47,
vibrate: [100, 50, 200],
badge: '/statics/icons/app-icon-96x96.png',
tag: 'confirm-notification',
renotify: true, // if it's already sent, will Vibrate anyway
actions: [
{ action: 'confirm', title: 'Okay', icon: '/statics/icons/app-icon-96x96.png' },
{ action: 'cancel', title: 'Cancel', icon: '/statics/icons/app-icon-96x96.png' }
]
}
if ('serviceWorker' in navigator) {
navigator.serviceWorker.ready
2019-07-10 11:37:00 +02:00
.then((swreg) => {
swreg.showNotification('Successfully subscribed!', options)
})
}
}
}
,
dataURItoBlob(dataURI) {
const byteString = atob(dataURI.split(',')[1])
const mimeString = dataURI.split(',')[0].split(':')[1].split(';')[0]
const ab = new ArrayBuffer(byteString.length)
const ia = new Uint8Array(ab)
for (let i = 0; i < byteString.length; i++) {
ia[i] = byteString.charCodeAt(i)
}
const blob = new Blob([ab], { type: mimeString })
return blob
}
,
showNotificationExample() {
let options = null
const mythis = this
if ('serviceWorker' in navigator) {
options = {
body: mythis.$t('notification.subscribed'),
icon: '/statics/icons/android-chrome-192x192.png',
image: '/statics/images/imglogonotif.png',
dir: 'ltr',
lang: 'enUs', // BCP 47,
vibrate: [100, 50, 200],
badge: '/statics/icons/android-chrome-192x192.png',
tag: 'confirm-notification',
renotify: true, // if it's already sent, will Vibrate anyway
actions: [
{ action: 'confirm', title: mythis.$t('dialog.ok'), icon: '/statics/icons/android-chrome-192x192.png' }
// { action: 'cancel', title: 'Cancel', icon: '/statics/icons/android-chrome-192x192.png', }
]
}
navigator.serviceWorker.ready
2019-07-10 11:37:00 +02:00
.then((swreg) => {
swreg.showNotification('aaa', options)
})
}
}
,
2019-07-10 11:37:00 +02:00
getemailto(text) {
return 'mailto:' + text
}
,
2019-07-10 11:37:00 +02:00
askfornotification() {
tools.showNotif(this.$q, this.$t('notification.waitingconfirm'), { color: 'positive', icon: 'notifications' })
Notification.requestPermission((result) => {
console.log('User Choice', result)
if (result === 'granted') {
tools.showNotif(this.$q, this.$t('notification.confirmed'), { color: 'positive', icon: 'notifications' })
} else {
tools.showNotif(this.$q, this.$t('notification.denied'), { color: 'negative', icon: 'notifications' })
// displayConfirmNotification();
}
})
}
,
2019-07-10 11:37:00 +02:00
heightgallery(coeff) {
// console.log('heightgallery')
return tools.heightGallVal(coeff).toString() + 'px'
},
heightGallVal(coeff = 1.33) {
let maxh2 = 0
let myw = Screen.width
if (!this.isMobile())
if (GlobalStore.state.leftDrawerOpen)
myw -= 300
if (!this.isMobile())
if (GlobalStore.state.RightDrawerOpen)
myw -= 300
maxh2 = (myw / coeff) + 20
if (maxh2 > 500)
maxh2 = 500
return maxh2
}
,
2019-07-10 11:37:00 +02:00
myheight_imgtitle(myheight ?, myheightmobile ?) {
let maxheight = 0
if (!!myheight) {
maxheight = myheight
if (myheight > 0) {
if (myheight > 1000) {
maxheight = 1000
} else {
2019-10-10 16:53:33 +02:00
maxheight = parseInt(myheight, 10)
}
}
} else {
maxheight = 500
}
const maxh2 = this.heightGallVal()
// console.log('maxh2', maxh2)
// console.log('maxheight', maxheight)
let ris = 0
if (maxh2 < maxheight)
ris = maxh2
else
ris = maxheight
if (!!myheightmobile) {
if (this.isMobile() && maxh2 > myheightmobile)
ris = parseInt(myheightmobile, 10)
2019-07-10 11:37:00 +02:00
}
// console.log('ris', ris)
return ris
}
,
2019-07-10 11:37:00 +02:00
myheight_dialog() {
if (Screen.width < 410) {
return '337'
2019-07-10 11:37:00 +02:00
} else if (Screen.width < 600) {
return '400'
} else {
return '500'
}
},
2019-07-10 11:37:00 +02:00
styles_imgtitle(sized ?: string) {
if (!!sized) {
return sized
2019-07-10 11:37:00 +02:00
} else {
if (Screen.width < 410) {
return 'max-height: 250px'
} else {
return 'max-height: 350px'
}
2019-07-10 11:37:00 +02:00
}
}
,
2019-07-10 11:37:00 +02:00
/*
<q-img
src="https://cdn.quasar.dev/img/image-src.png"
srcset="https://cdn.quasar.dev/img/image-1x.png 400w,
https://cdn.quasar.dev/img/image-2x.png 800w,
https://cdn.quasar.dev/img/image-3x.png 1200w,
https://cdn.quasar.dev/img/image-4x.png 1600w"
sizes="(max-width: 400px) 400w,
(min-width: 400px) and (max-width: 800px) 800w,
(min-width: 800px) and (max-width: 1200px) 1200w,
(min-width: 1200px) 1600w"
style="height: 280px; max-width: 300px"
>
<div class="absolute-bottom text-body1 text-center">
With srcset & sizes
</div>
</q-img>
*/
getsizes() {
return '(max-width: 400px) 400w, ' +
'(min-width: 400px) and (max-width: 800px) 800w, ' +
'(min-width: 800px) and (max-width: 1200px) 1200w, ' +
'(min-width: 1200px) 1600w'
}
,
2019-07-10 11:37:00 +02:00
maxwidth_imgtitle() {
if (Screen.width < 410) {
2019-07-10 11:37:00 +02:00
return 'max-width: 250px'
} else {
return 'max-width: 350px'
}
}
,
2019-07-10 11:37:00 +02:00
isMobile() {
return (Screen.width < 450)
}
,
2019-07-10 11:37:00 +02:00
mywidth_imgtitle() {
if (Screen.width < 450) {
2019-07-10 11:37:00 +02:00
return '250'
} else if (Screen.width < 600) {
return '350'
} else {
return '350'
}
}
,
2019-07-10 11:37:00 +02:00
mymargin_imgtitle() {
return 'auto'
}
,
2019-07-10 11:37:00 +02:00
showthumbnails() {
if (Screen.width < 410) {
2019-07-10 11:37:00 +02:00
return false
} else if (Screen.width < 600) {
return true
} else {
return true
}
}
,
2019-07-10 11:37:00 +02:00
padTime(val) {
val = Math.floor(val)
if (val < 10) {
return '0' + val
}
return val + ''
}
,
2019-07-10 11:37:00 +02:00
getLocale(vero ?: boolean) {
2019-07-12 14:09:44 +02:00
if (UserStore) {
if (UserStore.state) {
return UserStore.state.lang
}
}
if (!vero)
return process.env.LANG_DEFAULT
else
return ''
}
,
2019-07-10 11:37:00 +02:00
2019-07-12 14:09:44 +02:00
addDays(mydate, days) {
return date.addToDate(mydate, { days })
}
,
addMinutes(mydate, minutes) {
return date.addToDate(mydate, { minutes })
}
,
gettitlemain(datamain: ITimeLineMain) {
if (datamain.titlemain[toolsext.getLocale()])
return datamain.titlemain[toolsext.getLocale()]
else {
return datamain.titlemain[static_data.arrLangUsed[0]]
}
}
,
getwwithwhocoll(datamain: ICollaborations) {
if (datamain.withwhom_title[toolsext.getLocale()])
return datamain.withwhom_title[toolsext.getLocale()]
else {
return datamain.withwhom_title[static_data.arrLangUsed[0]]
}
}
,
gettextcoll(data: IColl) {
if (data.subtitle[toolsext.getLocale()])
return data.subtitle[toolsext.getLocale()]
else {
return data.subtitle[static_data.arrLangUsed[0]]
}
}
,
gettitlecoll(data: IColl) {
if (data.title[toolsext.getLocale()])
return data.title[toolsext.getLocale()]
else {
return data.title[static_data.arrLangUsed[0]]
}
}
,
gettextdescr(data: ITimeLineEntry, numdescr = 'description'
) {
if (!!data[numdescr]) {
if (data[numdescr][toolsext.getLocale()])
return data[numdescr][toolsext.getLocale()]
else {
return data[numdescr][static_data.arrLangUsed[0]]
}
} else {
return ''
}
}
,
getlink(data: ITimeLineEntry) {
if (data.link_text[toolsext.getLocale()])
return data.link_text[toolsext.getLocale()]
else {
return data.link_text[static_data.arrLangUsed[0]]
}
}
,
getlinkurl(data: ITimeLineEntry) {
if (data.link_url_lang) {
if (data.link_url_lang[toolsext.getLocale()]) {
return data.link_url_lang[toolsext.getLocale()]
} else {
return data.link_url
}
} else {
return data.link_url
}
},
appid() {
return process.env.APP_ID
},
getLabelByItem(item, mythis) {
if (!!item.name)
return mythis.$t(item.name)
else
return item.text
},
getimgev(ev) {
if (!!ev.img_small)
return `statics/` + ev.img_small
else if (!!ev.img)
return `statics/` + ev.img
else
return ''
},
getimgbysize(dir: string, file: string) {
const myimage = dir + file
// console.log('includes = ', static_data.preLoadImages.map((a) => a.imgname).includes(myimage), myimage)
let ris = ''
if (this.isMobile() && (preloadedimages().map((a) => a.imgname).includes(myimage))) {
ris = dir + 'mobile/' + file
} else {
ris = myimage
}
// console.log('getimgbysize', ris)
return ris
},
getaltimg(dir: string, file: string, alt?: string) {
const myimage = dir + file
const myrec = static_data.preLoadImages.find((rec) => rec.imgname === myimage)
if (myrec)
return (myrec) ? myrec.alt : 'my image'
else
return alt
},
getimgFullpathbysize(fileimg: string) {
if (!fileimg)
return { path: '', file: fileimg }
const ind = fileimg.lastIndexOf('/')
if (ind > 0) {
2019-10-10 16:53:33 +02:00
return { path: fileimg.substring(0, ind + 1), file: fileimg.substring(ind + 1) }
} else {
return { path: '', file: fileimg }
}
}
,
2019-07-10 11:37:00 +02:00
2019-10-10 16:53:33 +02:00
convertHTMLtoText(myhtml) {
let msg = myhtml
msg = msg.replace('&quot;', '"')
msg = msg.replace('&gt;', '>')
msg = msg.replace('&lt;', '<')
msg = msg.replace('&amp;', '&')
msg = msg.replace('<br>', '\n')
2019-10-10 16:53:33 +02:00
return msg
}
,
gettextevent(mythis, myevent: IEvents) {
// return '"' + myevent.title + '" (' + func_tools.getDateStr(myevent.date) + ') - ' + myevent.time
return '"' + myevent.title + '" (' + tools.getstrDateEmailTime(mythis, myevent.dateTimeStart) + ')'
2019-10-10 16:53:33 +02:00
},
getlangforQuasar(mylang) {
if (mylang === 'enUs')
return 'en-us'
else
return mylang
},
2019-10-10 16:53:33 +02:00
setLangAtt(mylang) {
console.log('setLangAtt =', mylang)
// console.log('PRIMA this.$q.lang.isoName', this.$q.lang.isoName)
// dynamic import, so loading on demand only
import(`quasar/lang/${this.getlangforQuasar(mylang)}`).then((lang) => {
2019-10-10 16:53:33 +02:00
console.log(' Import dinamically lang =', lang)
Quasar.lang.set(this.getlangforQuasar(lang.default))
2019-10-10 16:53:33 +02:00
import(`../../statics/i18n`).then(() => {
console.log(' *** MY LANG DOPO=', Quasar.lang.isoName)
})
})
// this.$q.lang.set(mylang)
}
,
getappname(mythis, short) {
2019-10-10 16:53:33 +02:00
if (mythis === undefined)
return ''
if (mythis.$t === undefined)
return ''
if (short) {
2019-10-10 16:53:33 +02:00
return mythis.$t('msg.myAppNameShort')
} else {
return mythis.$t('msg.myAppName')
}
},
loginOk(mythis, ispageLogin: boolean) {
// console.log('loginOk')
if (toolsext.getLocale() !== '') {
mythis.$i18n.locale = toolsext.getLocale()
} // Set Lang
else {
UserStore.mutations.setlang(mythis.$i18n.locale)
} // Set Lang
if (process.env.DEBUG) {
console.log('LANG ORA=', toolsext.getLocale())
}
globalroutines(mythis, 'loadapp', '')
tools.SignIncheckErrors(mythis, tools.OK, ispageLogin)
}
,
loginInCorso(mythis) {
// console.log('loginInCorso')
let msg = mythis.$t('login.incorso')
// if (process.env.DEBUG) {
// msg += ' ' + process.env.MONGODB_HOST
// }
mythis.$q.loading.show({ message: msg })
}
,
2019-12-31 00:44:43 +01:00
getUrlSite() {
const url = window.location.href
const arr = url.split('/')
return arr[0] + '//' + arr[2]
},
SignIncheckErrors(mythis, riscode, ispageLogin ?: boolean) {
// console.log('SignIncheckErrors: ', riscode)
try {
if (riscode === tools.OK) {
tools.showNotif(mythis.$q, mythis.$t('login.completato'), { color: 'positive', icon: 'check' })
if (ispageLogin) {
mythis.$router.push('/')
}
} else if (riscode === serv_constants.RIS_CODE_LOGIN_ERR) {
// Wait N seconds to avoid calling many times...
return new Promise((resolve, reject) => {
setTimeout(() => {
resolve('anything')
}, 3000)
}).then(() => {
setTimeout(() => {
// console.log('HIDE...')
mythis.$q.loading.hide()
}, 500)
tools.showNotif(mythis.$q, mythis.$t('login.errato'), { color: 'negative', icon: 'notifications' })
mythis.iswaitingforRes = false
if (ispageLogin) {
GlobalStore.state.RightDrawerOpen = true
// mythis.$router.push('/signin')
}
})
} else if (riscode === tools.ERR_SERVERFETCH) {
tools.showNotif(mythis.$q, mythis.$t('fetch.errore_server'), { color: 'negative', icon: 'notifications' })
} else if (riscode === tools.ERR_GENERICO) {
const msg = mythis.$t('fetch.errore_generico') + UserStore.mutations.getMsgError(riscode)
tools.showNotif(mythis.$q, msg, { color: 'negative', icon: 'notifications' })
} else {
tools.showNotif(mythis.$q, 'Errore num ' + riscode, { color: 'negative', icon: 'notifications' })
}
if (riscode !== serv_constants.RIS_CODE_LOGIN_ERR) {
mythis.iswaitingforRes = false
setTimeout(() => {
mythis.$q.loading.hide()
}, 200)
}
} finally {
// ...
}
}
,
SignUpcheckErrors(mythis, riscode: number, msg: string) {
console.log('SignUpcheckErrors', riscode)
let endload = true
2019-12-29 23:29:56 +01:00
if (riscode === serv_constants.RIS_CODE_EMAIL_ALREADY_EXIST) {
tools.showNotif(mythis.$q, mythis.$t('reg.err.duplicate_email'))
} else if (riscode === serv_constants.RIS_CODE_USER_ALREADY_EXIST) {
tools.showNegativeNotif(mythis.$q, mythis.$t('reg.err.user_already_exist'))
} else if (riscode === serv_constants.RIS_CODE_USER_EXTRALIST_NOTFOUND) {
tools.showNegativeNotif(mythis.$q, mythis.$t('reg.err.user_extralist_not_found') + ' ' + msg)
} else if (riscode === serv_constants.RIS_CODE_USER_NOT_THIS_APORTADOR) {
tools.showNegativeNotif(mythis.$q, mythis.$t('reg.err.user_not_this_aportador') + ' ' + msg)
2019-12-29 23:29:56 +01:00
} else if (riscode === serv_constants.RIS_CODE_USERNAME_ALREADY_EXIST) {
tools.showNotif(mythis.$q, mythis.$t('reg.err.duplicate_username'))
} else if (riscode === tools.ERR_SERVERFETCH) {
tools.showNotif(mythis.$q, mythis.$t('fetch.errore_server'))
} else if (riscode === tools.ERR_GENERICO) {
const msg = mythis.$t('fetch.errore_generico') + UserStore.mutations.getMsgError(riscode)
tools.showNotif(mythis.$q, msg)
} else if (riscode === tools.OK) {
mythis.$router.push('/regok')
tools.showNotif(mythis.$q, mythis.$t('components.authentication.email_verification.link_sent'), {
color: 'green',
textColor: 'black'
})
} else {
tools.showNotif(mythis.$q, 'Errore num ' + riscode)
}
return endload
}
,
isCssColor(color) {
return !!color && !!color.match(/^(#|(rgb|hsl)a?\()/)
}
,
displayClasses(eventparam) {
return {
// [`bg-${eventparam.bgcolor}`]: !tools.isCssColor(eventparam.bgcolor),
'text-white': !tools.isCssColor(eventparam.bgcolor)
}
}
,
displayStyles(eventparam) {
const s = { color: '' }
if (tools.isCssColor(eventparam.bgcolor)) {
// s['background-color'] = eventparam.bgcolor
s.color = colors.luminosity(eventparam.bgcolor) > 0.5 ? 'black' : 'white'
}
return s
}
,
CancelBookingEvent(mythis, eventparam: IEvents, bookeventid: string, notify: boolean) {
console.log('CancelBookingEvent ', eventparam)
tools.askConfirm(mythis.$q, translate('cal.titlebooking'), translate('cal.cancelbooking') + ' ' + tools.gettextevent(mythis, eventparam) + '?', translate('dialog.yes'), translate('dialog.no'), mythis, '', lists.MenuAction.DELETE, 0, {
param1: bookeventid,
param2: notify,
param3: eventparam.title
})
}
,
CancelEvent(mythis, eventparam: IEvents) {
console.log('CancelEvent ', eventparam)
tools.askConfirm(mythis.$q, translate('cal.event'), translate('cal.cancelevent') + ' ' + tools.gettextevent(mythis, eventparam) + '?', translate('dialog.yes'), translate('dialog.no'), mythis, '', lists.MenuAction.DELETE_EVENT, 0, {
param1: eventparam,
param2: true
})
}
,
ActionRecTable(mythis, action, table, id, item, askaction) {
// console.log('ActionRecTable', id)
return tools.askConfirm(mythis.$q, 'Action', translate(askaction) + '?', translate('dialog.yes'), translate('dialog.no'), mythis, table, action, 0, {
param1: id,
param2: item
})
}
,
async createNewRecord(mythis, table, data) {
const mydata = {
table,
data
}
return await
GlobalStore.actions.saveTable(mydata)
.then((record) => {
if (record) {
tools.showPositiveNotif(mythis.$q, mythis.$t('db.recupdated'))
} else {
tools.showNegativeNotif(mythis.$q, mythis.$t('db.recfailed'))
}
return record
})
},
getheight(mythis) {
// return height()
return mythis.$q.screen.height
},
getwidth(mythis, withright = false, withleft = true) {
// return height()
let myw = mythis.$q.screen.width
if (withleft) {
if (GlobalStore.state.leftDrawerOpen)
myw -= 300
}
if (withright)
if (GlobalStore.state.RightDrawerOpen)
myw -= 300
return myw
},
getwidthscale(mythis, mywidth, maxwidth) {
if (this.isMobile()) {
// if (mywidth > this.getwidth(mythis) - 20)
mywidth = this.getwidth(mythis, false, false) - 32
// console.log('mywidth', mywidth)
return mywidth
} else {
// console.log('this.getwidth(mythis) = ', this.getwidth(mythis))
let myw = mywidth + ((this.getwidth(mythis, true) - mywidth) * 0.6)
// console.log('myw1 = ', myw)
if (myw > maxwidth)
myw = maxwidth
if (myw > this.getwidth(mythis) - 24)
myw = this.getwidth(mythis) - 24
// console.log('myw = ', myw)
return myw
}
},
getheightbywidth(mythis, mywidth, myheight, maxwidth) {
// console.log('getheightbywidth')
const myw = this.getwidthscale(mythis, mywidth, maxwidth)
return myw * (myheight / mywidth)
},
isIsoDate(str) {
if (!/\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}.\d{3}Z/.test(str)) return false
const d = new Date(str)
return d.toISOString() === str
},
getLastDateReadReset() {
return new Date(1999, 1, 1, 0, 0, 0)
},
isBitActive(bit, whattofind) {
if (whattofind > 0)
return ((bit & whattofind) === whattofind)
else
return false
},
SetBit(myval, bit) {
myval = myval | bit
return myval
},
getUnique(arr, comp) {
const unique = arr
.map(e => e[comp])
// store the keys of the unique objects
.map((e, i, final) => final.indexOf(e) === i && i)
// eliminate the dead keys & store unique objects
.filter(e => arr[e]).map(e => arr[e])
return unique
},
getColorByIndexBest(index) {
if (index < this.listBestColor.length - 1)
return this.listBestColor[index]
else
return 'primary'
},
getCookie(mytok, def?) {
const ris = Cookies.get(mytok)
2019-12-29 23:29:56 +01:00
// console.log('getCookie', ris)
if (!!ris) {
return ris
} else {
return def
}
},
setCookie(mytok, value: string) {
return Cookies.set(mytok, value)
},
removeCookie(mytok) {
return Cookies.remove(mytok)
},
notshowPwd(payload) {
const mypay = { ...payload }
try {
if (!!mypay.password) {
mypay.password = '**********'
}
} catch (e) {
console.log('error', e)
}
return mypay
},
scrollToTop() {
const element = document.getElementById('mypage')
this.scrollToElement(element)
},
scrollToElementId(myid) {
const element = document.getElementById(myid)
this.scrollToElement(element)
},
scrollToElement(el) {
const target = getScrollTarget(el)
const offset = el.offsetTop
const duration = 500
console.log('target', target, 'offset', offset, 'duration', duration)
setScrollPosition(target, offset, duration)
},
getCellForWhatsapp(numbercell) {
if (!numbercell)
return ''
let mynum = numbercell.replace(/\-/g, '')
const intcode = GlobalStore.getters.getValueSettingsByKey('INT_CODE', false)
if (numbercell.substring(0, 1) !== '+')
mynum = intcode + mynum
else
mynum = mynum.substring(1)
return mynum
},
getHttpForWhatsapp(numbercell) {
if (!numbercell)
return ''
const mynum = this.getCellForWhatsapp(numbercell)
if (mynum)
return 'https://wa.me/' + mynum
else
return ''
},
getHttpForTelegram(usertelegram) {
if (usertelegram)
return 'https://t.me/' + usertelegram
else
return ''
},
getsuffisso() {
if (tools.isTest())
return 'TEST: '
else
return ''
},
metafunc(mythis) {
return {
title: mythis.$t('msg.myAppName'),
titleTemplate: (title) => `${tools.getsuffisso()} ${mythis.mymeta.title} - ${mythis.$t('msg.myAppName')}`,
meta: {
keywords: {
name: 'keywords',
content: mythis.mymeta.keywords
},
description: {
name: 'description',
content: mythis.mymeta.description
},
equiv: { 'http-equiv': 'Content-Type', 'content': 'text/html; charset=UTF-8' }
}
}
},
isObject(anything) {
// Object.create(null) instanceof Object → false
return Object(anything) === anything
2019-12-04 18:21:17 +01:00
},
isDebug() {
return process.env.DEV
},
isTest() {
return process.env.ISTEST === '1'
},
geturlupload() {
return process.env.MONGODB_HOST + '/upload'
},
getheaders() {
return [{ name: 'x-auth', value: UserStore.state.x_auth_token }]
},
2019-12-28 02:17:07 +01:00
getextfile(filename) {
return filename.split('.').pop().toLowerCase()
},
getelembylang(arr) {
const mylang = toolsext.getLocale()
for (const elem in arr) {
if (arr[elem][mylang])
return arr[elem][mylang]
}
},
isChristmasHoliday() {
const now = new Date()
return ((now.getMonth() === 11 && now.getDate() > 20) || (now.getMonth() === 0 && now.getDate() < 8))
2019-12-31 00:44:43 +01:00
},
CapitalizeAllWords(str) {
const splitStr = str.toLowerCase().split(' ')
for (var i = 0; i < splitStr.length; i++) {
// You do not need to check if i is larger than splitStr length, as your for does that for you
// Assign it back to the array
splitStr[i] = splitStr[i].charAt(0).toUpperCase() + splitStr[i].substring(1)
}
// Directly return the joined string
return splitStr.join(' ')
},
getValDb(keystr, serv, def?, table?, subkey?) {
if (table === 'users') {
if (keystr === 'profile') {
return UserStore.state.my.profile[subkey]
} else {
return UserStore.state.my[keystr]
}
} else {
const ris = GlobalStore.getters.getValueSettingsByKey(keystr, serv)
if (ris === '')
if (def !== undefined)
return def
else
return ''
else
return ris
}
},
getkey(youtube, title, isnum) {
let mykey = 'MP4'
if (youtube)
mykey = 'YT'
if (isnum) {
mykey += '_NUM'
} else {
if (title)
mykey += '_TITLE_'
else
mykey += '_VIDEO_'
}
return mykey
},
heightgallvideo() {
const h = this.heightgallery(this.getValDb('YT_W', false) / this.getValDb('YT_H', false))
return h
},
getvideourl(index, youtube) {
const myvideo = this.getValDb(this.getkey(youtube, false, false) + index, false)
if (myvideo)
if (youtube)
return myvideo
else
return this.getpath(myvideo)
else
return ''
},
getvideonum(youtube) {
return this.getValDb(this.getkey(youtube, false, true), false)
},
getvideomp4yt(index) {
return [{ src: 'https://www.youtube.com/embed/' + this.getvideourl(index, true), type: 'video/mp4' }
]
},
getvideomp4src(index) {
return [{ src: this.getvideourl(index, false), type: 'video/mp4' }
]
},
getvideoyt(index) {
return 'https://www.youtube.com/embed/' + this.getvideourl(index, true)
},
getvideobyidyoutube(key) {
return 'https://www.youtube.com/embed/' + key
},
getpath(myvideo) {
return 'statics/video/' + func_tools.getLocale() + '/' + myvideo
},
mygetarrValDb(keystr, serv) {
const myval = GlobalStore.getters.getValueSettingsByKey(keystr, serv)
// console.log('AA: myval', myval)
try {
if (myval) {
// console.log(' Entro')
const myrec = JSON.parse(myval)
// console.log('*************** getarrValDb')
// console.table(myrec)
return myrec
} else {
// console.log('NO MYVAL')
return []
}
} catch (e) {
console.log('Errore: ', e)
return []
}
},
getvideotitle(index, youtube) {
const mykey = this.getkey(youtube, true, false) + index
const ris = this.mygetarrValDb(mykey, false)
return this.getelembylang(ris)
},
getvideoposter(index) {
return ''
},
clone(obj) {
if (null === obj || 'object' !== typeof obj) return obj
const copy = obj.constructor()
for (const attr in obj) {
if (obj.hasOwnProperty(attr)) copy[attr] = obj[attr]
}
return copy
},
geticon(langin) {
if (langin === '')
return ''
try {
let lang = langin.toUpperCase()
if (lang === 'IT')
return 'fa-flag-it'
else if (lang === 'ES')
return 'fa-flag-es'
else if (lang === 'US')
return 'fa-flag-us'
else if ((lang === 'GB') || (lang === 'UK'))
return 'fa-flag-gb'
else if (lang === 'DE')
return 'fa-flag-de'
else if (lang === 'FR')
return 'fa-flag-fr'
else if (lang === 'SI')
return 'fa-flag-si'
else if (lang === 'CH')
return 'fa-flag-ch'
else if (lang === 'CM')
return 'fa-flag-cm'
else if (lang === 'CO')
return 'fa-flag-co'
else if (lang === 'PE')
return 'fa-flag-pe'
else if (lang === 'SM')
return 'fa-flag-sm'
else if (lang === 'HR')
return 'fa-flag-hr'
else if (lang === 'RO')
return 'fa-flag-ro'
else if (lang === 'CL')
return 'fa-flag-cl'
return ''
} catch (e) {
return ''
}
},
removespaces(mystr) {
return mystr.replace(/\s+/g, '')
},
copyStringToClipboard(mythis, mystr) {
copyToClipboard(mystr).then(() => {
tools.showNotif(mythis.$q, mythis.$t('dialog.copyclipboard') + ' \'' + mystr + '\'')
})
},
getNationsByNationality(nat, code) {
if (nat === 'IT') {
return 'Italy'
} else if (nat === 'SI') {
return 'Slovenia'
} else if (nat === 'ES') {
return 'Spain'
} else if (nat === 'DE') {
return 'Germany'
} else if (nat === 'FR') {
return 'France'
} else if (nat === 'US') {
return 'United States'
} else if (nat === 'CA') {
return 'Canada'
} else if (nat === 'MA') {
return 'Morocco'
} else if (nat === 'LT') {
return 'Lithuania'
} else if (nat === 'HR') {
return 'Croatia'
} else if (nat === 'HU') {
return 'Hungary'
} else if (nat === 'CH') {
return 'Switzerland'
} else if (nat === 'CM') {
return 'Cameroon'
} else if (nat === 'CO') {
return 'Colombia'
} else if (nat === 'PE') {
return 'Peru'
} else if (nat === 'PL') {
return 'Poland'
} else if (nat === 'SM') {
return 'San Marino'
} else if (nat === 'PT') {
return 'Portugal'
} else if (nat === 'UK') {
return 'United Kingdom'
} else if (nat === 'UA') {
return 'Ukraine'
} else if (nat === 'RO') {
return 'Romania'
} else if (nat === 'CL') {
return 'Chile'
}
},
getLinkZoom() {
let id = ''
if (GlobalStore.state.calzoom.length > 0) {
id = GlobalStore.state.calzoom.slice(-1)[0].id_conf_zoom.toString()
} else {
id = '6668882000'
}
return 'https://zoom.us/j/' + id
},
myprintf( ) {
}
2019-07-10 11:37:00 +02:00
// getLocale() {
// if (navigator.languages && navigator.languages.length > 0) {
// return navigator.languages[0]
// } else {
// return navigator.userLanguages || navigator.language || navigator.browserLanguages || 'it-IT'
// }
// }
}