- Invia e Ricevi RIS (grafica aggiornata)

- Visualizzazione Movimenti (ultimi e successivi), per singolo e di tutti
This commit is contained in:
Surya Paolo
2024-10-11 02:29:29 +02:00
parent f9277f3a01
commit ec356c70d9
123 changed files with 3595218 additions and 638 deletions

View File

@@ -1,18 +1,17 @@
APP_VERSION="1.1.3" APP_VERSION="1.1.3"
SERVICE_WORKER_FILE="service-worker.js" SERVICE_WORKER_FILE="service-worker.js"
APP_ID="17" APP_ID="13"
DIRECTORY_LOCAL="newfreeplanet" DIRECTORY_LOCAL="newfreeplanet"
DIRECTORY_SERVER="freeplanet_serverside" DIRECTORY_SERVER="freeplanet_serverside"
SERVERDIR_WEBSITE="" SERVERDIR_WEBSITE=""
SERVERPW_WEBSITE="" SERVERPW_WEBSITE=""
APP_URL="https://localhost" APP_URL="https://localhost"
URL_FACEBOOK="https://www.facebook.com/freeplanetapp" URL_FACEBOOK="https://www.facebook.com/freeplanetapp"
PROVA_PAOLO="PROVA ENV FUNZIONA!"
LANG_DEFAULT="it" LANG_DEFAULT="it"
PAO_APP_ID="KKPPAA5KJK435J3KSS9F9D8S9F8SD98F9SDF" PAO_APP_ID="KKPPAA5KJK435J3KSS9F9D8S9F8SD98F9SDF"
MASTER_KEY="KKPPSS5KJK435J3KSS9F9D8S9F8SD3CR3T" MASTER_KEY="KKPPSS5KJK435J3KSS9F9D8S9F8SD3CR3T"
MONGODB_HOST="https://localhost:3000" MONGODB_HOST="https://localhost:3000"
LOGO_REG='piuchebuono-logo-full.png' LOGO_REG='riso-logo-full.png'
TEST_NAME="Paolo" TEST_NAME="Paolo"
TEST_SURNAME="Arena" TEST_SURNAME="Arena"
TEST_EMAIL="" TEST_EMAIL=""
@@ -25,6 +24,5 @@ DEBUG="1"
TELEGRAM_SUPPORT="" TELEGRAM_SUPPORT=""
PROJECT_ID_MAIN="5cc0a13fe5c9d156728f400a" PROJECT_ID_MAIN="5cc0a13fe5c9d156728f400a"
TEST_CELL="" TEST_CELL=""
ISTEST=1 ISTEST="1"
INLOCALE=1 INLOCALE="1"
BAK_MONGODB_HOST="http://192.168.0.200:3000"

View File

@@ -1 +1 @@
TERMINA DI LAVORARE SU riso.app: (Sovrascrivo !) TERMINA DI LAVORARE SU piuchebuono.app: (Sovrascrivo !)

View File

@@ -1,8 +1,8 @@
{ {
"name": "piuchebuono", "name": "riso",
"version": "1.1.3", "version": "1.1.3",
"description": "PiuCheBuono", "description": "Siamo la Rete Italiana di Scambio Orizzontale, abbiamo creato questa piattaforma per metterla al servizio di chi vuole riscoprire il valore della condivisione e della cooperazione. Valori semplici e profondi che ci aiutano a ritrovare il Senso della Vita, perduto in questa società consumista, e riporti quei Sani Pricìpi Naturali ed Umani di Fratellanza che intere popolazioni antiche conoscevano bene.",
"productName": "PiuCheBuono", "productName": "Riso",
"author": "Paolo Arena", "author": "Paolo Arena",
"private": true, "private": true,
"keywords": [], "keywords": [],
@@ -65,6 +65,7 @@
"npm": "^10.8.3", "npm": "^10.8.3",
"nprogress": "^0.2.0", "nprogress": "^0.2.0",
"pinia": "^2.2.4", "pinia": "^2.2.4",
"qrcode-vue3": "^1.7.1",
"quasar": "^2.17.0", "quasar": "^2.17.0",
"quasar-extras": "^2.0.9", "quasar-extras": "^2.0.9",
"register-service-worker": "^1.7.2", "register-service-worker": "^1.7.2",
@@ -86,6 +87,7 @@
"vue-timeago3": "^2.3.2", "vue-timeago3": "^2.3.2",
"vue2-dragula": "^2.5.5", "vue2-dragula": "^2.5.5",
"vue3-pdf-app": "^1.0.3", "vue3-pdf-app": "^1.0.3",
"vue3-qr-reader": "^1.0.0",
"vuex": "^4.1.0", "vuex": "^4.1.0",
"vuex-router-sync": "^6.0.0-rc.1" "vuex-router-sync": "^6.0.0-rc.1"
}, },
@@ -161,4 +163,4 @@
"npm": ">= 6.14.8", "npm": ">= 6.14.8",
"yarn": ">= 1.21.1" "yarn": ">= 1.21.1"
} }
} }

Binary file not shown.

Before

Width:  |  Height:  |  Size: 15 KiB

After

Width:  |  Height:  |  Size: 1.1 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 66 KiB

After

Width:  |  Height:  |  Size: 43 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 43 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 40 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 90 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 63 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 35 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 74 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 22 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 42 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 15 KiB

After

Width:  |  Height:  |  Size: 27 KiB

File diff suppressed because it is too large Load Diff

Binary file not shown.

Before

Width:  |  Height:  |  Size: 862 B

After

Width:  |  Height:  |  Size: 1.6 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.7 KiB

After

Width:  |  Height:  |  Size: 3.2 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 15 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 15 KiB

After

Width:  |  Height:  |  Size: 1.1 KiB

BIN
public/images/ferrara.jpg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 42 KiB

BIN
public/images/foto1.jpg Normal file → Executable file

Binary file not shown.

Before

Width:  |  Height:  |  Size: 87 KiB

After

Width:  |  Height:  |  Size: 12 KiB

BIN
public/images/foto2.jpg Normal file → Executable file

Binary file not shown.

Before

Width:  |  Height:  |  Size: 140 KiB

After

Width:  |  Height:  |  Size: 12 KiB

BIN
public/images/foto3.jpg Normal file → Executable file

Binary file not shown.

Before

Width:  |  Height:  |  Size: 165 KiB

After

Width:  |  Height:  |  Size: 12 KiB

Binary file not shown.

File diff suppressed because it is too large Load Diff

After

Width:  |  Height:  |  Size: 90 KiB

BIN
public/images/icon.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 10 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 52 KiB

After

Width:  |  Height:  |  Size: 43 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 618 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.2 MiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 88 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 311 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 36 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 63 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 3.5 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 5.5 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 10 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 17 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 23 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 26 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 36 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 39 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 53 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 7.1 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 7.7 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 10 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 12 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 63 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 163 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 142 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 30 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 43 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.0 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 138 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.8 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 185 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 11 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 17 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 21 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 23 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 30 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 33 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 42 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 7.6 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 8.1 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 11 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 12 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 44 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 634 KiB

BIN
public/images/riso_home.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 279 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 258 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 124 KiB

View File

@@ -152,7 +152,7 @@ module.exports = configure((ctx) => ({
}, },
devServer: { devServer: {
https: false, https: false,
port: 8088, port: 8084,
open: false, // opens browser window automatically open: false, // opens browser window automatically
hot: true, // Disable hot module replacement hot: true, // Disable hot module replacement
headers: { headers: {
@@ -313,9 +313,9 @@ module.exports = configure((ctx) => ({
}, },
manifest: { manifest: {
name: 'Più che Buono', name: 'Riso',
short_name: 'PiuCheBuono', short_name: 'Riso',
description: 'PiuCheBuono è un GAS e Bottega', description: 'Siamo la Rete Italiana di Scambio Orizzontale, abbiamo creato questa piattaforma per metterla al servizio di chi vuole riscoprire il valore della condivisione e della cooperazione. Valori semplici e profondi che ci aiutano a ritrovare il Senso della Vita, perduto in questa società consumista, e riporti quei Sani Pricìpi Naturali ed Umani di Fratellanza che intere popolazioni antiche conoscevano bene.',
display: 'standalone', display: 'standalone',
orientation: 'portrait', orientation: 'portrait',
background_color: '#fff', background_color: '#fff',
@@ -325,54 +325,54 @@ module.exports = configure((ctx) => ({
start_url: "/?homescreen=1", start_url: "/?homescreen=1",
icons: [ icons: [
{ {
src: 'images/pcb-android-icon-512x512.png', src: 'images/riso-android-icon-512x512.png',
sizes: '512x512', sizes: '512x512',
type: 'image/png', type: 'image/png',
}, },
{ {
src: 'images/pcb-android-icon-384x384.png', src: 'images/riso-android-icon-384x384.png',
sizes: '384x384', sizes: '384x384',
type: 'image/png', type: 'image/png',
}, },
{ {
src: 'images/pcb-android-icon-192x192.png', src: 'images/riso-android-icon-192x192.png',
sizes: '192x192', sizes: '192x192',
type: 'image/png', type: 'image/png',
}, },
{ {
src: 'images/pcb-android-icon-144x144.png', src: 'images/riso-android-icon-144x144.png',
sizes: '144x144', sizes: '144x144',
type: 'image/png', type: 'image/png',
}, },
{ {
src: 'images/pcb-android-icon-96x96.png', src: 'images/riso-android-icon-96x96.png',
sizes: '96x96', sizes: '96x96',
type: 'image/png', type: 'image/png',
}, },
{ {
src: 'images/pcb-apple-icon-120x120.png', src: 'images/riso-apple-icon-120x120.png',
sizes: '120x120', sizes: '120x120',
type: 'image/png', type: 'image/png',
}, },
{ {
src: 'images/pcb-apple-icon-144x144.png', src: 'images/riso-apple-icon-144x144.png',
sizes: '144x144', sizes: '144x144',
type: 'image/png', type: 'image/png',
}, },
{ {
src: 'images/pcb-apple-icon-152x152.png', src: 'images/riso-apple-icon-152x152.png',
sizes: '152x152', sizes: '152x152',
type: 'image/png', type: 'image/png',
}, },
{ {
src: 'images/pcb-apple-icon-180x180.png', src: 'images/riso-apple-icon-180x180.png',
sizes: '180x180', sizes: '180x180',
type: 'image/png', type: 'image/png',
}, },
], ],
related_applications: [{ related_applications: [{
"platform": "webapp", "platform": "webapp",
"url": "https://www.piuchebuono.app/manifest.json" "url": "https://www.riso.app/manifest.json"
}] }]
}, },
}, },
@@ -407,7 +407,7 @@ module.exports = configure((ctx) => ({
builder: { builder: {
// https://www.electron.build/configuration/configuration // https://www.electron.build/configuration/configuration
appId: 'PiuCheBuono', appId: 'Riso',
}, },
// "chain" is a webpack-chain object https://github.com/neutrinojs/webpack-chain // "chain" is a webpack-chain object https://github.com/neutrinojs/webpack-chain

View File

@@ -27,6 +27,7 @@
{{ $t('circuit.destin_non_ha_circuito_naz') }} {{ $t('circuit.destin_non_ha_circuito_naz') }}
<br /> <br />
</q-banner> </q-banner>
<br />
<div class="text-center" v-if="to_user"> <div class="text-center" v-if="to_user">
<q-btn <q-btn

View File

@@ -24,7 +24,12 @@ export default defineComponent({
type: String, type: String,
required: false, required: false,
default: '', default: '',
} },
causalDest: {
type: String,
required: false,
default: '',
},
}, },
components: { CLabel, CSendCoins }, components: { CLabel, CSendCoins },
setup(props) { setup(props) {

View File

@@ -1,26 +1,9 @@
<template> <template>
<div class="row justify-evenly items-center q-pa-sm q-ma-sm"> <div v-if="(getLinkUserTelegram() && tools.isUserOk()) || showBtnActivities"
class="row justify-evenly items-center q-pa-sm q-ma-sm">
<q-inner-loading id="spinner" :showing="loading"> <q-inner-loading id="spinner" :showing="loading">
<q-spinner-tail color="primary" size="4em"> </q-spinner-tail> <q-spinner-tail color="primary" size="4em"> </q-spinner-tail>
</q-inner-loading> </q-inner-loading>
<div>
<q-btn
v-if="
tools.isUserOk() &&
userStore.showButtonSendCoin(myuser) &&
(myuser.username !== userStore.my.username ||
userStore.hoContiCollettiviDaAmministrare() ||
userStore.hoContiComunitariDaAmministrare())
"
icon-right="img: images/1ris_rosso_100.png"
color="green"
size="md"
rounded
:label="$t('circuit.sendcoins')"
@click="clickOpenSendCoin"
>
</q-btn>
</div>
<div v-if="showBtnActivities"> <div v-if="showBtnActivities">
<q-btn <q-btn
v-if="site.confpages && site.confpages.showCompetenze" v-if="site.confpages && site.confpages.showCompetenze"
@@ -76,6 +59,7 @@
:showprop="showsendCoinTo" :showprop="showsendCoinTo"
:to_user="myuser" :to_user="myuser"
:sendRIS="sendRIS" :sendRIS="sendRIS"
:causalDest="causalDest"
@close="showsendCoinTo = false; loading = false" @close="showsendCoinTo = false; loading = false"
@showed="loading = false" @showed="loading = false"
> >

View File

@@ -40,3 +40,8 @@ $grayshadow: #555;
height: 100px; height: 100px;
padding: 0.5rem 0.5rem; padding: 0.5rem 0.5rem;
} }
.wrapword {
max-width: 100%; /* Assicurati che il wrapping non superi il contenitore */
overflow: hidden; /* Nasconde eventuali overflow */
}

View File

@@ -17,6 +17,11 @@ export default defineComponent({
required: false, required: false,
default: '', default: '',
}, },
small: {
type: Boolean,
required: false,
default: false,
}
}, },
components: {}, components: {},
setup(props) { setup(props) {
@@ -26,9 +31,18 @@ export default defineComponent({
tools.copyStringToClipboard($q, props.texttocopy, true) tools.copyStringToClipboard($q, props.texttocopy, true)
} }
function getclass() {
if (props.small) {
return 'text-h7'
} else {
return 'text-h5'
}
}
return { return {
copytoclip, copytoclip,
tools, tools,
getclass,
} }
}, },
}) })

View File

@@ -1,22 +1,53 @@
<template> <template>
<div class="q-ma-sm"> <div class="q-ma-sm">
<div :class="($q.dark.isActive ? `bg-black` : `bg-white`) + ` column cursor-pointer`" @click="copytoclip"> <div
<q-field outlined :label="title" stack-label class="text-center cursor-pointer" label-color="blue"> :class="[
<template v-slot:prepend v-if="!tools.isMobile()"> $q.dark.isActive ? `bg-black text-white` : `bg-white text-black`,
<q-btn round dense flat icon="far fa-copy"/> 'column cursor-pointer',
]"
@click="copytoclip"
style="max-width: 100%; width: auto; overflow: hidden"
>
<q-field
outlined
:label="title"
stack-label
class="text-center"
style="max-width: 100%"
label-color="blue"
>
<template v-slot:prepend>
<q-btn v-if="!$q.platform.is.mobile" round dense flat icon="far fa-copy" />
</template> </template>
<template v-slot:control> <template v-slot:control>
<div class="self-center full-width no-outline text-center wrapword text-h5" tabindex="0">{{tools.firstchars(texttocopy, 300)}}</div> <div
class="self-center q-my-xs no-outline text-center wrapword"
:class="getclass()"
style="
overflow-wrap: break-word;
word-wrap: break-word;
white-space: normal;
max-width: 100%; /* Assicurati di limitare la larghezza */
"
>
{{ tools.firstchars(texttocopy, 300) }}
</div>
</template> </template>
</q-field> </q-field>
<div class="row justify-center">
<q-btn
rounded
label="Copia il link" color="primary" @click="copytoclip"
>
</q-btn>
</div>
</div> </div>
</div> </div>
</template> </template>
<script lang="ts" src="./CCopyBtn.ts"> <script lang="ts" src="./CCopyBtn.ts"></script>
</script>
<style lang="scss" scoped> <style lang="scss" scoped>
@import './CCopyBtn.scss'; @import './CCopyBtn.scss';
</style> </style>

View File

@@ -0,0 +1,9 @@
.my-custom-container {
max-width: 100%; /* Imposta la larghezza massima per il contenitore */
}
.wrapword {
overflow: hidden; /* Nasconde il contenuto in eccesso */
white-space: nowrap; /* Impedisce il wrapping del testo */
text-overflow: ellipsis; /* Mostra "..." se il testo è troppo lungo */
}

View File

@@ -0,0 +1,56 @@
import { tools } from '../../store/Modules/tools'
import { useQuasar } from 'quasar'
import { useI18n } from '@src/boot/i18n'
import { useUserStore } from '@store/UserStore'
import { useGlobalStore } from '@store/globalStore'
import { defineComponent } from 'vue'
import { shared_consts } from '@/common/shared_vuejs'
export default defineComponent({
name: 'CCopyBtnSmall',
props: {
texttocopy: {
type: String,
required: true,
},
title: {
type: String,
required: false,
default: '',
},
small: {
type: Boolean,
required: false,
default: false,
}
},
components: {},
setup(props) {
const $q = useQuasar()
const { t } = useI18n()
async function copytoclipandsend() {
tools.copyStringToClipboard($q, props.texttocopy, true)
let msg = 'Questo è il link che puoi condividere per farti inviare i RIS:<br><br>👉🏻 ' + props.texttocopy
tools.sendMsgTelegramCmd($q, t, shared_consts.MsgTeleg.SHARE_TEXT, false, msg)
}
function getclass() {
if (props.small) {
return 'text-h7'
} else {
return 'text-h5'
}
}
return {
copytoclipandsend,
tools,
getclass,
t,
}
},
})

View File

@@ -0,0 +1,16 @@
<template>
<div class="" style="width: 100%; overflow: hidden;">
<div class="row justify-center">
{{ tools.firstchars(texttocopy, 80) }}
</div>
<div class="row justify-center q-mt-sm">
<q-btn rounded label="Condividi link" color="primary" @click="copytoclipandsend" />
</div>
</div>
</template>
<script lang="ts" src="./CCopyBtnSmall.ts"></script>
<style lang="scss" scoped>
@import './CCopyBtnSmall.scss';
</style>

View File

@@ -0,0 +1 @@
export {default as CCopyBtnSmall} from './CCopyBtnSmall.vue'

View File

@@ -0,0 +1,6 @@
.my-custom-border {
border: 1px solid #ccc; /* Imposta il colore del bordo (puoi personalizzare) */
background-color: #fff; /* Colore sfondo per il contenitore (puoi personalizzare) */
border-radius: 10px;
}

View File

@@ -0,0 +1,222 @@
import { computed, defineComponent, onMounted, PropType, ref, watch, reactive, toRefs } from 'vue'
import { ICalcStat, IOperators, ISearchList } from '../../model'
import { useUserStore } from '../../store/UserStore'
import { useRouter } from 'vue-router'
import { useGlobalStore } from '../../store/globalStore'
import { useCircuitStore } from '../../store/CircuitStore'
import { useI18n } from '../../boot/i18n'
import { shared_consts } from '@src/common/shared_vuejs'
import { costanti, IMainCard } from '@store/Modules/costanti'
import { CMyUser } from '../CMyUser'
import { CTitleBanner } from '../CTitleBanner'
import { CMyGroup } from '../CMyGroup'
import { CQRCode } from '../CQRCode'
import { CCopyBtnSmall } from '../CCopyBtnSmall'
import { CContactUser } from '../CContactUser'
import { CGridTableRec } from '../CGridTableRec'
import { CUserInfoAccount } from '../CUserInfoAccount'
import { tools } from '@store/Modules/tools'
import { useQuasar } from 'quasar'
import { colmyUserPeople } from '@store/Modules/fieldsTable'
export default defineComponent({
name: 'CFindUsers',
props: {
actionType: {
type: Number,
required: false,
default: costanti.ACTIONTYPE.SEND_RIS,
},
sendRIS: {
type: String,
required: false,
default: '',
},
},
components: {
CMyUser, CMyGroup, CUserInfoAccount, CCopyBtnSmall,
CTitleBanner, CContactUser, CGridTableRec, CQRCode
},
setup(props) {
const userStore = useUserStore()
const globalStore = useGlobalStore()
const circuitStore = useCircuitStore()
const { t } = useI18n()
const $q = useQuasar()
const $router = useRouter()
const receiveRislist = computed(() => globalStore.datastat ? globalStore.datastat.receiveRislist : [])
const receiveRislistgroup = computed(() => globalStore.datastat ? globalStore.datastat.receiveRislistgroup : [])
const arrfilterand: any = ref([])
const filtercustom: any = ref([])
const searchList = ref(<ISearchList[]>[])
const filter = ref(costanti.FIND_PEOPLE)
const loading = ref(false)
const tipoConto = ref(0)
const contact = computed(() => userStore.my)
const searchType = ref('username')
const usersList = ref(<any>{ show: false, title: '', list: [], listgroup: [] })
const options = ref([
{
label: 'Cerca per Nome o Username',
value: 'username'
},
{
label: 'Lista dei Riceventi di oggi',
value: 'receivers'
},
{
label: 'Scansiona il QRCode del Destinatario',
value: 'qrcode'
},
])
const arrTypesAccounts = ref(<any>[
{
label: t('circuit.user'),
value: shared_consts.AccountType.USER,
},
{
label: t('circuit.conticollettivi'),
value: shared_consts.AccountType.COLLECTIVE_ACCOUNT,
}
])
function getFilterProvinceByRegion(recProvince: any, index: number, arr: any) {
const recreg: any = searchList.value.find((rec) => rec.table === 'regions')
if (recreg) {
return recProvince.reg === recreg.value
} else {
return true
}
}
function mounted() {
searchList.value = [
{
label: 'Regione',
table: 'regions',
key: 'idReg',
type: costanti.FieldType.select,
value: tools.getCookie(tools.COOK_SEARCH + 'regions_fr', costanti.FILTER_TUTTI),
keycookie: '_fr',
addall: true,
arrvalue: [],
filter: null,
useinput: false,
icon: 'fas fa-globe-europe'
},
{
label: 'Provincia',
table: 'provinces',
key: 'profile.resid_province',
type: costanti.FieldType.select,
value: tools.getCookie(tools.COOK_SEARCH + 'provinces_fr', costanti.FILTER_TUTTI),
keycookie: '_fr',
addall: true,
arrvalue: [],
filter: getFilterProvinceByRegion,
useinput: true,
icon: 'flag',
tablesel: 'provinces',
},
]
filtercustom.value = []
arrfilterand.value = []
const filt_loaded = tools.getCookie(tools.COOK_SEARCH + tools.FRIENDS_SEARCH, costanti.FIND_PEOPLE, true)
filter.value = filt_loaded ? filt_loaded : costanti.FIND_PEOPLE
updateUserListRIS()
sendCoinsToClick()
}
function extraparams() {
return {
lookup1: {
lk_tab: 'provinces',
lk_LF: 'profile.resid_province',
lk_FF: 'prov',
lk_as: 'mycities',
lk_proj: {
username: 1,
name: 1,
surname: 1,
verified_by_aportador: 1,
'profile.handshake': 1,
'profile.img': 1,
'profile.mygroups': 1,
'profile.qualifica': 1,
'profile.resid_province': 1,
'mycities.reg': 1,
}
},
}
}
onMounted(mounted)
async function updateUserListRIS() {
const userStore = useUserStore()
loading.value = true
await globalStore.getStatSite()
usersList.value.list = receiveRislist
usersList.value.listgroup = receiveRislistgroup
loading.value = false
}
async function sendCoinsToClick() {
usersList.value.show = true;
usersList.value.title = t('circuit.sendcoins');
usersList.value.list = receiveRislist
usersList.value.listgroup = receiveRislistgroup
}
return {
userStore,
tools,
costanti,
shared_consts,
arrTypesAccounts,
loading,
contact,
t,
extraparams,
colmyUserPeople,
searchList,
options,
searchType,
updateUserListRIS,
usersList,
receiveRislist,
receiveRislistgroup,
tipoConto,
CQRCode,
}
},
})

View File

@@ -0,0 +1,116 @@
<template>
<q-option-group
class="q-ma-xs"
style="text-align: left !important"
v-model="searchType"
:options="options"
color="primary"
/>
<q-tab-panels v-model="searchType" animated class="shadow-2 rounded-borders">
<q-tab-panel name="username">
<CGridTableRec
prop_mytable="users"
prop_mytitle=""
subtitle=""
:prop_mycolumns="colmyUserPeople"
prop_colkey="_id"
col_title="username"
:vertical="costanti.VISUTABLE_LISTA"
nodataLabel=" "
:prop_search="true"
:prop_showfilter="true"
hint="Cerca il nome o Username"
:hintinbtnsearch="true"
:findByDebounce="true"
:showSearchOnTop="false"
:finder="true"
:choose_visutype="false"
:finder_noNull="false"
:finder_noNullFilters="true"
:options="shared_consts.OPTIONS_SEARCH_USER_ALL_WORDS"
:butt_modif_new="false"
noresultLabel="Username, Nome o Cognome non trovato"
:arrfilters="arrfilterand"
:filtercustom="filtercustom"
:prop_searchList="searchList"
:showType="costanti.SHOW_USERINFO"
:showCol="false"
:extraparams="extraparams()"
:actionType="actionType"
>
</CGridTableRec>
</q-tab-panel>
<q-tab-panel name="receivers">
<div class="row centeritems">
<q-btn-toggle
v-if="arrTypesAccounts.length > 0"
v-model="tipoConto"
class="my-custom-toggle"
no-caps
rounded
unelevated
toggle-color="primary"
color="white"
text-color="primary"
:options="arrTypesAccounts"
/>
<div v-if="tipoConto === shared_consts.AccountType.USER">
<div v-for="(rec, i) in usersList.list" :key="i">
<div class="q-pa-xs q-ma-xs q-border q-rounded my-custom-border">
<CMyUser
:mycontact="rec"
:visu="costanti.FIND_PEOPLE"
@setCmd="tools.setCmd"
:actionType="actionType"
>
</CMyUser>
<CContactUser
:myuser="rec"
:showBtnActivities="false"
:sendRIS="tools.isUserOk() ? sendRIS : false"
:actionType="actionType"
/>
</div>
</div>
</div>
<div
v-else-if="tipoConto === shared_consts.AccountType.COLLECTIVE_ACCOUNT"
>
<div v-for="(grp, i) in usersList.listgroup" :key="i">
<CMyGroup :mygrp="grp" :visu="costanti.USER_GROUPS" :noaut="true">
</CMyGroup>
</div>
</div>
</div>
<br />
<div class="row centeritems justify-evenly items-center">
<q-btn
icon="autorenew"
rounded
glossy
dense
color="primary"
:label="$t('dialog.update_receivers')"
:disable="loading"
@click="updateUserListRIS()"
>
</q-btn>
<q-spinner-radio v-if="loading" class="q-ma-sm" color="brown" />
<div class="q-ma-sm">&nbsp;</div>
<br>
</div>
</q-tab-panel>
<q-tab-panel name="qrcode">
<CQRCode :read="true"></CQRCode>
</q-tab-panel>
</q-tab-panels>
</template>
<script lang="ts" src="./CFindUsers.ts">
</script>
<style lang="scss" scoped>
@import './CFindUsers.scss';
</style>

View File

@@ -0,0 +1 @@
export {default as CFindUsers} from './CFindUsers.vue'

View File

@@ -90,6 +90,21 @@ export default defineComponent({
required: false, required: false,
default: false, default: false,
}, },
hintinbtnsearch: {
type: Boolean,
required: false,
default: false,
},
findByDebounce: {
type: Boolean,
required: false,
default: false,
},
showSearchOnTop: {
type: Boolean,
required: false,
default: false,
},
hint: { hint: {
type: String, type: String,
required: false, required: false,
@@ -145,6 +160,11 @@ export default defineComponent({
required: false, required: false,
default: '', default: '',
}, },
actionType: {
type: Number,
required: false,
default: 0,
},
/* keyMain: { /* keyMain: {
type: String, type: String,
required: false, required: false,
@@ -1339,7 +1359,7 @@ export default defineComponent({
serverData.value = [] serverData.value = []
numRecLoaded.value = 0 numRecLoaded.value = 0
pagination.value.page = 0 pagination.value.page = 0
search.value = search.value.trim() search.value = search.value ? search.value.trim() : ''
// console.log('refresh') // console.log('refresh')
// console.log('search', search) // console.log('search', search)

View File

@@ -2,7 +2,7 @@
<div v-if="tools.isDebugOn()"></div> <div v-if="tools.isDebugOn()"></div>
<div :class="$q.screen.lt.sm ? `` : `q-pa-xs`" v-if="isfinishLoading"> <div :class="$q.screen.lt.sm ? `` : `q-pa-xs`" v-if="isfinishLoading">
<q-toggle <q-toggle
v-if="tools.isManager() && !showMap" v-if="tools.isManager() && !showMap && editOn"
v-model="editOn" v-model="editOn"
color="green" color="green"
icon="fas fa-pencil-alt" icon="fas fa-pencil-alt"
@@ -241,21 +241,17 @@
</div> </div>
</q-slide-transition> </q-slide-transition>
<div v-if="prop_search || canEdit"> <div v-if="prop_search || canEdit" class="q-gutter-sm">
<div <div v-if="searchList && finder" class="row items-start">
v-if="searchList && finder"
class="row justify-between q-mb-sm q-mx-sm"
>
<q-btn <q-btn
class="" v-if="searchList && searchList.length > 0"
dense :dense="search"
:label=" class="q-mx-xs"
!showfilter ? $t('grid.openfilter') : $t('grid.closefilter')
"
color="positive" color="positive"
:icon="!showfilter ? 'fas fa-filter' : 'fas fa-arrow-up'" :icon="!showfilter ? 'fas fa-filter' : 'fas fa-arrow-up'"
@click="showfilter = !showfilter" @click="showfilter = !showfilter"
><q-badge >
<q-badge
v-if="getNumFilterSelected()" v-if="getNumFilterSelected()"
color="red" color="red"
floating floating
@@ -264,34 +260,53 @@
{{ getNumFilterSelected() }} {{ getNumFilterSelected() }}
</q-badge> </q-badge>
</q-btn> </q-btn>
<q-btn
v-if="prop_search" <q-input
class="" v-model="search"
filled
dense dense
:label="t('grid.search')" type="search"
debounce="500"
:hint="!hintinbtnsearch ? hint: ''"
:error-message="noresultLabel"
:error="(getNumRecFromQuery() === 0 && !startsearch) && myfilter !== ''"
:label="hintinbtnsearch ? hint : $t('grid.search')"
@keyup.enter="doSearch"
@clear="myfilter = ''; doSearch()"
@update:model-value="findByDebounce ? doSearch() : null"
:clearable="!!myfilter"
class="col q-mx-xs"
style="max-width: 400px"
>
<template v-if="!search" v-slot:prepend>
<q-icon name="search" />
</template>
</q-input>
<q-btn
v-if="prop_search && myfilter || search"
color="primary" color="primary"
icon="fas fa-search" icon="fas fa-search"
@click="showSearchDialog = true" @click="showSearchOnTop ? showSearchDialog = true : doSearch()"
> />
</q-btn>
<q-btn-toggle <q-btn-toggle
v-if="shared_consts.TABLES_VISU_MAP.includes(mytable)" v-if="shared_consts.TABLES_VISU_MAP.includes(mytable)"
v-model="showMap" v-model="showMap"
push
glossy
dense dense
spread
no-caps
toggle-color="secondary" toggle-color="secondary"
:options="[ :options="[
{ {
label: t('grid.showmap'), label: $t('grid.showmap'),
value: true, value: true,
icon: 'fas fa-map-marked-alt', icon: 'fas fa-map-marked-alt',
}, },
{ label: t('grid.showlist'), value: false, icon: 'fas fa-list' }, { label: $t('grid.showlist'), value: false, icon: 'fas fa-list' },
]" ]"
/> />
</div> </div>
<q-space></q-space> <q-space></q-space>
<q-select <q-select
:behavior="$q.platform.is.ios === true ? 'dialog' : 'menu'" :behavior="$q.platform.is.ios === true ? 'dialog' : 'menu'"
@@ -448,6 +463,7 @@
:visu="visufind" :visu="visufind"
:groupname="extrafield" :groupname="extrafield"
:circuitname="circuitname" :circuitname="circuitname"
:actionType="actionType"
:labelextra="col_title ? row[col_title] : ''" :labelextra="col_title ? row[col_title] : ''"
:labelFooter=" :labelFooter="
col_footer col_footer
@@ -1319,7 +1335,7 @@
> >
<q-card class="dialog_card"> <q-card class="dialog_card">
<q-bar dense class="bg-primary text-white"> <q-bar dense class="bg-primary text-white">
{{t('dialog.insert')}} {{ mytitlenew }}: {{ t('dialog.insert') }} {{ mytitlenew }}:
<q-space /> <q-space />
<q-btn flat round color="white" icon="close" v-close-popup></q-btn> <q-btn flat round color="white" icon="close" v-close-popup></q-btn>
</q-bar> </q-bar>

View File

@@ -26,6 +26,11 @@ export default defineComponent({
required: false, required: false,
default: '' default: ''
}, },
showbuttolastmov: {
type: Boolean,
required: false,
default: false
},
}, },
emits: ['loaded'], emits: ['loaded'],
setup(props, { emit }) { setup(props, { emit }) {
@@ -35,10 +40,12 @@ export default defineComponent({
const globalStore = useGlobalStore() const globalStore = useGlobalStore()
const { t } = useI18n(); const { t } = useI18n();
const loadingvalues = ref(false)
const numtransaz = ref(0) const numtransaz = ref(0)
const prectransaz = ref(0) const prectransaz = ref(0)
const tab = ref('tutti') const tab = ref('tutti')
const nummovTodownload = ref(5)
const mylist = computed(() => { const mylist = computed(() => {
if (globalStore.datastat || userStore.my.profile) { if (globalStore.datastat || userStore.my.profile) {
@@ -128,6 +135,13 @@ export default defineComponent({
mounted() mounted()
}) })
async function addlastmov() {
nummovTodownload.value += 5
loadingvalues.value = true
await globalStore.loadLastMovements(nummovTodownload.value)
loadingvalues.value = false
}
return { return {
userStore, userStore,
@@ -140,6 +154,8 @@ export default defineComponent({
navigabyMov, navigabyMov,
numtransaz, numtransaz,
tab, tab,
loadingvalues,
addlastmov,
} }
} }
}) })

View File

@@ -70,6 +70,19 @@
> >
</c-single-movement> </c-single-movement>
</q-list> </q-list>
<q-inner-loading id="spinner" :showing="loadingvalues">
<q-spinner-tail size="3em" color="primary" />
</q-inner-loading>
<div v-if="showbuttolastmov" class="row justify-center">
<q-btn
rounded
dense
class="text-center"
color="primary"
:label="t('circuit.show_next_mov')"
@click="addlastmov()"
/>
</div>
</template> </template>
<script lang="ts" src="./CMovements.ts"> <script lang="ts" src="./CMovements.ts">

View File

@@ -94,6 +94,7 @@ export default defineComponent({
const mystr = getlinkpage() const mystr = getlinkpage()
tools.copyStringToClipboard($q, mystr, true) tools.copyStringToClipboard($q, mystr, true)
tools.sendMsgTelegramCmd($q, t, shared_consts.MsgTeleg.SHARE_TEXT, false, mystr) tools.sendMsgTelegramCmd($q, t, shared_consts.MsgTeleg.SHARE_TEXT, false, mystr)
return true return true
} }

View File

@@ -46,7 +46,7 @@
:small="true" :small="true"
:open="false" :open="false"
> >
<CMovements @loaded="movcaricati" :username="username"> <CMovements @loaded="movcaricati" :username="username" :showbuttolastmov="false">
<div class="row justify-center"><q-btn <div class="row justify-center"><q-btn
rounded rounded
dense dense

View File

@@ -476,7 +476,7 @@
</div> </div>
<div v-else-if="myel.type === shared_consts.ELEMTYPE.MOVEMENTS"> <div v-else-if="myel.type === shared_consts.ELEMTYPE.MOVEMENTS">
<div v-if="editOn" class="elemEdit">Lista Movimenti</div> <div v-if="editOn" class="elemEdit">Lista Movimenti</div>
<CMovements></CMovements> <CMovements :showbuttolastmov="true"></CMovements>
</div> </div>
<div v-else-if="myel.type === shared_consts.ELEMTYPE.CSENDRISTO"> <div v-else-if="myel.type === shared_consts.ELEMTYPE.CSENDRISTO">
<div v-if="editOn" class="elemEdit">CSendRISTo</div> <div v-if="editOn" class="elemEdit">CSendRISTo</div>

View File

@@ -115,8 +115,8 @@ export default defineComponent({
if (numAskTrust.value > 0 || props.modelValue === costanti.ASK_TRUST) if (numAskTrust.value > 0 || props.modelValue === costanti.ASK_TRUST)
mybutt.push({ label: t('mypages.request_trust') + ' (' + numAskTrust.value + ')', value: costanti.ASK_TRUST }) mybutt.push({ label: t('mypages.request_trust') + ' (' + numAskTrust.value + ')', value: costanti.ASK_TRUST })
if (numTrusted.value > 0 || props.modelValue === costanti.TRUSTED) //if (numTrusted.value > 0 || props.modelValue === costanti.TRUSTED)
mybutt.push({ label: t('mypages.trusted') + ' (' + numTrusted.value + ')', value: costanti.TRUSTED }) // mybutt.push({ label: t('mypages.trusted') + ' (' + numTrusted.value + ')', value: costanti.TRUSTED })
if (numRejected.value > 0 || props.modelValue === costanti.REJECTED) if (numRejected.value > 0 || props.modelValue === costanti.REJECTED)
mybutt.push({ label: t('mypages.rejected') + ' (' + numRejected.value + ')', value: costanti.REJECTED }) mybutt.push({ label: t('mypages.rejected') + ' (' + numRejected.value + ')', value: costanti.REJECTED })

View File

@@ -22,6 +22,11 @@ export default defineComponent({
required: false, required: false,
default: null, default: null,
}, },
actionType: {
type: Number,
required: false,
default: costanti.ACTIONTYPE.NONE,
},
myusername: { myusername: {
type: String, type: String,
required: false, required: false,

View File

@@ -12,7 +12,7 @@
</q-avatar> </q-avatar>
</q-item-section> </q-item-section>
<q-item-section @click="naviga(`/my/` + contact.username)"> <q-item-section @click="actionType === costanti.ACTIONTYPE.SEND_RIS ? naviga(`/my/` + contact.username + '?sr=0') : naviga(`/my/` + contact.username)">
<q-item-label v-if="labelextra && labelextra !== contact.username" <q-item-label v-if="labelextra && labelextra !== contact.username"
><strong>{{ labelextra }}</strong></q-item-label ><strong>{{ labelextra }}</strong></q-item-label
> >
@@ -422,10 +422,13 @@
clickable clickable
v-close-popup v-close-popup
dense dense
@click="naviga(`/my/` + contact.username + '?sendris=0')" @click="naviga(`/my/` + contact.username + '?sr=0')"
> >
<q-item-section avatar> <q-item-section avatar>
<q-icon color="positive" name="img: images/1ris_rosso_100.png" /> <q-icon
color="positive"
name="img: images/1ris_rosso_100.png"
/>
</q-item-section> </q-item-section>
<q-item-section>{{ $t('circuit.sendcoins') }}</q-item-section> <q-item-section>{{ $t('circuit.sendcoins') }}</q-item-section>
</q-item> </q-item>
@@ -454,7 +457,10 @@
" "
> >
<q-item-section avatar> <q-item-section avatar>
<q-icon color="positive" name="img: images/1ris_rosso_100.png" /> <q-icon
color="positive"
name="img: images/1ris_rosso_100.png"
/>
</q-item-section> </q-item-section>
<q-item-section> <q-item-section>
{{ $t('circuit.enablefido') }} {{ $t('circuit.enablefido') }}
@@ -787,203 +793,216 @@
side side
v-else-if="visu === costanti.FIND_PEOPLE || visu === costanti.HANDSHAKE" v-else-if="visu === costanti.FIND_PEOPLE || visu === costanti.HANDSHAKE"
> >
<q-item-label> <div v-if="actionType === costanti.ACTIONTYPE.SEND_RIS">
<q-btn <q-icon
v-if="contact.username !== userStore.my.username" name="img: images/1ris_rosso_100.png"
rounded :size="`lg`"
dense />
icon="fas fa-ellipsis-h" </div>
> <div v-else>
<!-- </q-btn></q-btn>:icon=" <q-item-label>
<q-btn
v-if="contact.username !== userStore.my.username"
rounded
dense
icon="fas fa-ellipsis-h"
>
<!-- </q-btn></q-btn>:icon="
userStore.IsMyFriendByUsername(contact.username) userStore.IsMyFriendByUsername(contact.username)
? `fas fa-ellipsis-h` ? `fas fa-ellipsis-h`
: `fas fa-user` : `fas fa-user`
"--> "-->
<q-menu> <q-menu>
<q-list style="min-width: 200px"> <q-list style="min-width: 200px">
<q-item <q-item
v-if=" v-if="
userStore.showButtonSendCoin(contact) && userStore.showButtonSendCoin(contact) &&
(contact.username !== userStore.my.username || (contact.username !== userStore.my.username ||
userStore.hoContiCollettiviDaAmministrare() || userStore.hoContiCollettiviDaAmministrare() ||
userStore.hoContiComunitariDaAmministrare()) userStore.hoContiComunitariDaAmministrare())
" "
clickable clickable
v-close-popup v-close-popup
dense dense
@click="naviga(`/my/` + contact.username + '?sendris=0')" @click="naviga(`/my/` + contact.username + '?sr=0')"
> >
<q-item-section avatar> <q-item-section avatar>
<q-icon color="positive" name="img: images/1ris_rosso_100.png" /> <q-icon
</q-item-section> color="positive"
<q-item-section>{{ $t('circuit.sendcoins') }}</q-item-section> name="img: images/1ris_rosso_100.png"
</q-item> />
<q-item </q-item-section>
clickable <q-item-section>{{
v-close-popup $t('circuit.sendcoins')
dense }}</q-item-section>
@click="naviga(`/my/` + contact.username)" </q-item>
> <q-item
<q-item-section avatar> clickable
<q-icon color="primary" name="fas fa-user" /> v-close-popup
</q-item-section> dense
<q-item-section>{{ $t('shared.profile') }}</q-item-section> @click="naviga(`/my/` + contact.username)"
</q-item> >
<q-item-section avatar>
<q-icon color="primary" name="fas fa-user" />
</q-item-section>
<q-item-section>{{ $t('shared.profile') }}</q-item-section>
</q-item>
<q-item <q-item
v-if=" v-if="
costanti.ENABLE_FRIENDS && costanti.ENABLE_FRIENDS &&
!userStore.IsMyFriendByUsername(contact.username) && !userStore.IsMyFriendByUsername(contact.username) &&
!userStore.IsAskedFriendByUsername(contact.username) !userStore.IsAskedFriendByUsername(contact.username)
" "
clickable clickable
v-close-popup v-close-popup
@click=" @click="
setCmd( setCmd(
$q, $q,
shared_consts.FRIENDSCMD.REQFRIEND, shared_consts.FRIENDSCMD.REQFRIEND,
userStore.my.username, userStore.my.username,
true, true,
contact.username contact.username
) )
" "
> >
<q-item-section avatar> <q-item-section avatar>
<q-icon color="positive" name="fas fa-user-plus" /> <q-icon color="positive" name="fas fa-user-plus" />
</q-item-section> </q-item-section>
<q-item-section>{{ <q-item-section>{{
$t('friends.ask_friend') $t('friends.ask_friend')
}}</q-item-section> }}</q-item-section>
</q-item> </q-item>
<q-item <q-item
v-else-if=" v-else-if="
costanti.ENABLE_FRIENDS && costanti.ENABLE_FRIENDS &&
!userStore.IsMyFriendByUsername(contact.username) && !userStore.IsMyFriendByUsername(contact.username) &&
userStore.IsAskedFriendByUsername(contact.username) userStore.IsAskedFriendByUsername(contact.username)
" "
clickable clickable
v-close-popup v-close-popup
@click=" @click="
setCmd( setCmd(
$q, $q,
shared_consts.FRIENDSCMD.REQFRIEND, shared_consts.FRIENDSCMD.REQFRIEND,
userStore.my.username, userStore.my.username,
false, false,
contact.username contact.username
) )
" "
> >
<q-item-section avatar> <q-item-section avatar>
<q-icon color="negative" name="fas fa-user-minus" /> <q-icon color="negative" name="fas fa-user-minus" />
</q-item-section> </q-item-section>
<q-item-section>{{ <q-item-section>{{
$t('friends.cancel_ask_friend') $t('friends.cancel_ask_friend')
}}</q-item-section> }}</q-item-section>
</q-item> </q-item>
<q-item <q-item
v-else-if=" v-else-if="
costanti.ENABLE_FRIENDS && costanti.ENABLE_FRIENDS &&
userStore.IsMyFriendByUsername(contact.username) userStore.IsMyFriendByUsername(contact.username)
" "
style="min-width: 200px" style="min-width: 200px"
clickable clickable
v-close-popup v-close-popup
@click=" @click="
setCmd( setCmd(
$q, $q,
shared_consts.FRIENDSCMD.REMOVE_FROM_MYFRIENDS, shared_consts.FRIENDSCMD.REMOVE_FROM_MYFRIENDS,
userStore.my.username, userStore.my.username,
'', '',
contact.username contact.username
) )
" "
> >
<q-item-section avatar> <q-item-section avatar>
<q-icon color="negative" name="fas fa-user-minus" /> <q-icon color="negative" name="fas fa-user-minus" />
</q-item-section> </q-item-section>
<q-item-section>{{ <q-item-section>{{
$t('friends.remove_from_myfriends') $t('friends.remove_from_myfriends')
}}</q-item-section> }}</q-item-section>
</q-item> </q-item>
<q-item <q-item
v-if="!userStore.IsHandShakeByMe(contact)" v-if="!userStore.IsHandShakeByMe(contact)"
clickable clickable
v-close-popup v-close-popup
@click=" @click="
setCmd( setCmd(
$q, $q,
shared_consts.FRIENDSCMD.SETHANDSHAKE, shared_consts.FRIENDSCMD.SETHANDSHAKE,
userStore.my.username, userStore.my.username,
true, true,
contact.username contact.username
) )
" "
> >
<q-item-section avatar> <q-item-section avatar>
<q-icon color="positive" name="far fa-handshake" /> <q-icon color="positive" name="far fa-handshake" />
</q-item-section> </q-item-section>
<q-item-section>{{ <q-item-section>{{
$t('handshake.ask_handshake') $t('handshake.ask_handshake')
}}</q-item-section> }}</q-item-section>
</q-item> </q-item>
<q-item <q-item
v-else v-else
style="min-width: 200px" style="min-width: 200px"
clickable clickable
v-close-popup v-close-popup
@click=" @click="
setCmd( setCmd(
$q, $q,
shared_consts.FRIENDSCMD.REMOVE_FROM_MYHANDSHAKE, shared_consts.FRIENDSCMD.REMOVE_FROM_MYHANDSHAKE,
userStore.my.username, userStore.my.username,
'', '',
contact.username contact.username
) )
" "
> >
<q-item-section avatar> <q-item-section avatar>
<q-icon color="negative" name="fas fa-handshake-slash" /> <q-icon color="negative" name="fas fa-handshake-slash" />
</q-item-section> </q-item-section>
<q-item-section>{{ <q-item-section>{{
$t('handshake.remove_from_myhandshake') $t('handshake.remove_from_myhandshake')
}}</q-item-section> }}</q-item-section>
</q-item> </q-item>
<q-item <q-item
v-if="circuit" v-if="circuit"
clickable clickable
v-close-popup v-close-popup
@click="showAccountInfo = true" @click="showAccountInfo = true"
> >
<q-item-section avatar> <q-item-section avatar>
<q-icon name="fas fa-info" /> <q-icon name="fas fa-info" />
</q-item-section> </q-item-section>
<q-item-section>{{ <q-item-section>{{
$t('groups.infoaccount') $t('groups.infoaccount')
}}</q-item-section> }}</q-item-section>
</q-item> </q-item>
<q-item <q-item
clickable clickable
v-close-popup v-close-popup
@click=" @click="
tools.reportUser( tools.reportUser(
$q, $q,
userStore.my.username, userStore.my.username,
contact.username contact.username
) )
" "
> >
<q-item-section avatar> <q-item-section avatar>
<q-icon color="negative" name="fas fa-flag" /> <q-icon color="negative" name="fas fa-flag" />
</q-item-section> </q-item-section>
<q-item-section>{{ <q-item-section>{{
$t('friends.report_user') $t('friends.report_user')
}}</q-item-section> }}</q-item-section>
</q-item> </q-item>
</q-list> </q-list>
</q-menu> </q-menu>
</q-btn> </q-btn>
</q-item-label> </q-item-label>
</div>
</q-item-section> </q-item-section>
<q-item-section side v-else-if="visu === costanti.REJECTED"> <q-item-section side v-else-if="visu === costanti.REJECTED">
<q-item-label> <q-item-label>

View File

@@ -0,0 +1,17 @@
.button_download{
display: inline-block !important;
padding: 10px 20px !important;
font-size: 16px !important;
font-weight: 500;
color: #ffffff !important;
background-color: #027be3 !important;
/* Colore primario di Quasar */
border: none !important;
border-radius: 4px !important;
cursor: pointer;
text-align: center;
text-decoration: none;
transition: background-color 0.3s, box-shadow 0.3s;
}

View File

@@ -0,0 +1,87 @@
import {
computed,
provide, defineComponent, onBeforeMount, onBeforeUnmount, onMounted, ref, toRef, toRefs, watch, reactive
} from 'vue'
import { tools } from '@store/Modules/tools'
import { costanti } from '@costanti'
import { useGlobalStore } from '@store/globalStore'
import { useUserStore } from '@store/UserStore'
import { shared_consts } from '@/common/shared_vuejs'
import { useI18n } from '@/boot/i18n'
import { toolsext } from '@store/Modules/toolsext'
import { useQuasar } from 'quasar'
import QrcodeVue from 'qrcode-vue3'
import { QrStream, QrCapture, QrDropzone } from 'vue3-qr-reader'
import { useRouter } from 'vue-router'
export default defineComponent({
name: 'CQRCode',
emits: [''],
props: {
link: {
type: String,
required: false,
default: '',
},
textlink: {
type: String,
required: false,
default: '',
},
read: {
type: Boolean,
required: false,
default: false,
},
},
components: {
QrcodeVue, QrStream,
QrCapture,
QrDropzone
},
setup(props, { attrs, slots, emit }) {
const { t } = useI18n()
const $q = useQuasar()
const globalStore = useGlobalStore()
const userStore = useUserStore()
const $router = useRouter()
const state = reactive({
data: null
})
function onDecode(data: any) {
if (data)
state.data = data
}
const text = ref('');
function naviga(path: string) {
$router.push(path)
}
onMounted(mounted)
function mounted() {
// ...
}
return {
t,
tools,
costanti,
toolsext,
text,
userStore,
...toRefs(state),
onDecode,
naviga,
}
},
})

View File

@@ -0,0 +1,70 @@
<template>
<div>
<div v-if="read">
<div class="stream">
<qr-stream @decode="onDecode" class="mb">
<div style="color: red" class="frame"></div>
</qr-stream>
<br />
<qr-capture @decode="onDecode" class="mb"></qr-capture>
</div>
<div class="row justify-center q-ma-sm">
<q-btn
v-if="data && data.startsWith('http')"
class="q-ma-sm"
dense
color="positive"
@click="tools.openUrl(data)"
label="APRI PAGINA"
>
</q-btn>
<br />
<div v-if="data && data.startsWith('http')" class="result">
Link: {{ data }}
</div>
</div>
</div>
<div v-else>
<div class="q-ma-sm">
{{textlink}}<br>
{{link}}
</div>
<qrcode-vue
:width="250"
:height="250"
:qrOptions="{ typeNumber: 0, mode: 'Byte', errorCorrectionLevel: 'H' }"
:imageOptions="{ hideBackgroundDots: true, imageSize: 0.4, margin: 0 }"
:dotsOptions="{
type: 'dots',
color: '#26249a',
gradient: {
type: 'linear',
rotation: 0,
colorStops: [
{ offset: 0, color: '#26249a' },
{ offset: 1, color: '#26249a' },
],
},
}"
:image="tools.getimglogo()"
:cornersSquareOptions="{ type: 'dot', color: '#000000' }"
:cornersDotOptions="{ type: undefined, color: '#000000' }"
fileExt="png"
:download="true"
:value="link"
downloadButton="button_download"
:downloadOptions="{
name: 'qrcode-riso-' + userStore.my.username,
extension: 'png',
}"
/>
</div>
</div>
</template>
<script lang="ts" src="./CQRCode.ts">
</script>
<style lang="scss" scoped>
@import './CQRCode.scss';
</style>

View File

@@ -0,0 +1 @@
export { default as CQRCode } from './CQRCode.vue'

Some files were not shown because too many files have changed in this diff Show More