Web Editor home made
1
.gitignore
vendored
@@ -40,3 +40,4 @@ key.pem
|
|||||||
_ALL_SITES/kolibrilab.it/.env.development
|
_ALL_SITES/kolibrilab.it/.env.development
|
||||||
_ALL_SITES/kolibrilab.it/.env.test
|
_ALL_SITES/kolibrilab.it/.env.test
|
||||||
_ALL_SITES/arcadei.it/.env.development
|
_ALL_SITES/arcadei.it/.env.development
|
||||||
|
public/upload/
|
||||||
|
|||||||
6
.vscode/launch.json
vendored
@@ -19,6 +19,12 @@
|
|||||||
"request": "launch",
|
"request": "launch",
|
||||||
"type": "node-terminal"
|
"type": "node-terminal"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"command": "npm run spanorefresh",
|
||||||
|
"name": "SPA no Refresh",
|
||||||
|
"request": "launch",
|
||||||
|
"type": "node-terminal"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"type": "node",
|
"type": "node",
|
||||||
"request": "launch",
|
"request": "launch",
|
||||||
|
|||||||
@@ -1,452 +0,0 @@
|
|||||||
|
|
||||||
.testo-banda {
|
|
||||||
//background: -webkit-gradient(linear, left top, left bottom, from(#3144f0), to(transparent));
|
|
||||||
//background: linear-gradient(180deg, #3144f0, transparent);
|
|
||||||
//background: rgba(0, 0, 0, .6)
|
|
||||||
}
|
|
||||||
|
|
||||||
$grayshadow: #555;
|
|
||||||
|
|
||||||
$textcol: blue;
|
|
||||||
$textcol_scuro: darkblue;
|
|
||||||
|
|
||||||
p {
|
|
||||||
margin: 0 0 1.25rem;
|
|
||||||
//text-shadow: .125rem .125rem .25rem $grayshadow;
|
|
||||||
}
|
|
||||||
|
|
||||||
h4 {
|
|
||||||
font-size: 1.25rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.mycard {
|
|
||||||
visibility: hidden;
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing {
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing_background {
|
|
||||||
background: #000 url(../../../public/images/foto1.jpg) no-repeat 50% fixed;
|
|
||||||
background-size: cover
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing > section {
|
|
||||||
display: -webkit-box;
|
|
||||||
display: -ms-flexbox;
|
|
||||||
display: flex;
|
|
||||||
-webkit-box-pack: center;
|
|
||||||
-ms-flex-pack: center;
|
|
||||||
justify-content: center;
|
|
||||||
//padding: 0 16px
|
|
||||||
}
|
|
||||||
|
|
||||||
.intro {
|
|
||||||
display: flex;
|
|
||||||
justify-content: space-between;
|
|
||||||
align-items: stretch;
|
|
||||||
/* flex-flow: row nowrap; */
|
|
||||||
|
|
||||||
padding: 1.25rem 0 1.25rem 0;
|
|
||||||
margin: .125rem;
|
|
||||||
|
|
||||||
* {
|
|
||||||
width: 100%;
|
|
||||||
flex: 1;
|
|
||||||
margin-left: auto;
|
|
||||||
margin-right: auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
&__associazione {
|
|
||||||
min-width: 350px;
|
|
||||||
}
|
|
||||||
|
|
||||||
&__comeassociarsi {
|
|
||||||
min-width: 350px;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.subtitle {
|
|
||||||
font-weight: 600;
|
|
||||||
text-align: center;
|
|
||||||
letter-spacing: 0.125rem;
|
|
||||||
text-transform: uppercase;
|
|
||||||
font-size: 1rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing > section.padding {
|
|
||||||
padding: 5.62rem 1rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing > section.padding_testo {
|
|
||||||
padding-top: 1.25rem;
|
|
||||||
padding-bottom: 1rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing > section.padding_gallery {
|
|
||||||
padding-top: 3.125rem;
|
|
||||||
padding-bottom: 5.625rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing > section > div {
|
|
||||||
position: relative;
|
|
||||||
width: 100%
|
|
||||||
}
|
|
||||||
|
|
||||||
.maxwidth1200 {
|
|
||||||
max-width: 1200px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing__toolbar {
|
|
||||||
background: -webkit-gradient(linear, left top, left bottom, from(#000), to(transparent));
|
|
||||||
background: linear-gradient(180deg, #000, transparent);
|
|
||||||
padding: 0 !important
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing__toolbar .q-btn {
|
|
||||||
border-radius: 0 0 .315rem .315rem;
|
|
||||||
-ms-flex-item-align: stretch;
|
|
||||||
align-self: stretch
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing__hero {
|
|
||||||
min-height: 50vh
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing__header {
|
|
||||||
height: 18vh
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing__arrow {
|
|
||||||
bottom: 1.5rem;
|
|
||||||
opacity: .4
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing__front {
|
|
||||||
background: -webkit-gradient(linear, left top, left bottom, from(transparent), color-stop(15%, rgba(0, 0, 0, .6)));
|
|
||||||
background: linear-gradient(180deg, transparent, rgba(0, 0, 0, .6) 15%)
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing__logo {
|
|
||||||
width: 9.40rem;
|
|
||||||
height: 9.40rem;
|
|
||||||
margin-top: 1.315rem;
|
|
||||||
//-webkit-animation: logo-rotate 240s linear infinite;
|
|
||||||
//animation: logo-rotate 240s linear infinite
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing__features .q-icon {
|
|
||||||
font-size: 4rem
|
|
||||||
}
|
|
||||||
|
|
||||||
h4 {
|
|
||||||
line-height: 1.5;
|
|
||||||
text-shadow: .25rem .25rem .5rem $grayshadow;
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing__features h4, .landing__features h6 {
|
|
||||||
margin: 1rem 0
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing__features p {
|
|
||||||
opacity: .7;
|
|
||||||
font-size: 1rem;
|
|
||||||
line-height: 1.5;
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing__footer {
|
|
||||||
//background: -webkit-gradient(linear, left top, left bottom, color-stop(65%, rgba(0, 0, 0, .1)), to(#000));
|
|
||||||
background: linear-gradient(180deg, rgba(0, 0, 0, .8) 95%, #FFF);
|
|
||||||
padding-top: 4.5rem !important;
|
|
||||||
padding-bottom: 4.5rem !important;
|
|
||||||
padding-left: 1.25rem;
|
|
||||||
padding-right: 1.25rem;
|
|
||||||
color: #9f9f9f;
|
|
||||||
}
|
|
||||||
|
|
||||||
.icon_contact:hover {
|
|
||||||
color: blue;
|
|
||||||
border-color: white;
|
|
||||||
border-width: .0625rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing__footer .doc-link {
|
|
||||||
color: $textcol;
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing__footer .doc-link:hover {
|
|
||||||
opacity: .8
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing__swirl-bg {
|
|
||||||
background-repeat: no-repeat !important;
|
|
||||||
background-position: top;
|
|
||||||
background-size: contain !important;
|
|
||||||
background-image: url(../../../public/images/landing_first_section.png) !important
|
|
||||||
}
|
|
||||||
|
|
||||||
.feat-descr {
|
|
||||||
font-size: 1.15rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.feat-descr:hover {
|
|
||||||
transition: opacity 0.5s ease-in-out;
|
|
||||||
opacity: 0.9;
|
|
||||||
}
|
|
||||||
|
|
||||||
.q-col-gutter-sm {
|
|
||||||
padding: 3.125rem 3.125rem;
|
|
||||||
//margin-left: -48px
|
|
||||||
}
|
|
||||||
|
|
||||||
body.mobile .landing {
|
|
||||||
//background: unset
|
|
||||||
}
|
|
||||||
|
|
||||||
body.mobile .landing:before {
|
|
||||||
content: "";
|
|
||||||
position: fixed;
|
|
||||||
top: 0;
|
|
||||||
height: 100vh;
|
|
||||||
left: 0;
|
|
||||||
right: 0;
|
|
||||||
bottom: 0;
|
|
||||||
z-index: -1;
|
|
||||||
//background: #000 url(../../public/images/cover.jpg) 50%;
|
|
||||||
|
|
||||||
background-size: cover
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
@-webkit-keyframes logo-rotate {
|
|
||||||
to {
|
|
||||||
-webkit-transform: rotate(-1turn);
|
|
||||||
transform: rotate(-1turn)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@keyframes logo-rotate {
|
|
||||||
to {
|
|
||||||
-webkit-transform: rotate(-1turn);
|
|
||||||
transform: rotate(-1turn)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
.home {
|
|
||||||
//background-color: rgb(250, 250, 250);
|
|
||||||
padding: 3.125rem;
|
|
||||||
display: flex;
|
|
||||||
//flex-wrap: nowrap;
|
|
||||||
flex-direction: column;
|
|
||||||
align-items: center;
|
|
||||||
justify-content: space-between;
|
|
||||||
}
|
|
||||||
|
|
||||||
.btn-start {
|
|
||||||
margin: 3.125rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.shadow {
|
|
||||||
//color: white;
|
|
||||||
text-shadow: 0.125rem 0.125rem 0.25rem $grayshadow;
|
|
||||||
}
|
|
||||||
|
|
||||||
.text-h1, h1 {
|
|
||||||
font-size: 3rem;
|
|
||||||
font-weight: bold;
|
|
||||||
line-height: 3rem;
|
|
||||||
letter-spacing: -.01562em;
|
|
||||||
margin-bottom: 8px !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.text-h2 {
|
|
||||||
font-size: 3.75rem;
|
|
||||||
font-weight: 300;
|
|
||||||
line-height: 3.75rem;
|
|
||||||
letter-spacing: -.00833em;
|
|
||||||
}
|
|
||||||
|
|
||||||
.text-weight-bold {
|
|
||||||
font-weight: 700;
|
|
||||||
}
|
|
||||||
|
|
||||||
.text-vers {
|
|
||||||
font-size: 0.75rem;
|
|
||||||
font-weight: 400;
|
|
||||||
line-height: 1.75rem;
|
|
||||||
letter-spacing: .00937em;
|
|
||||||
text-shadow: .25rem .25rem .5rem $grayshadow;
|
|
||||||
}
|
|
||||||
|
|
||||||
.homep-cover-img-1 {
|
|
||||||
background: #000 url(../../../public/images/foto1.jpg) no-repeat 50% fixed;
|
|
||||||
//transition: background-image 1s ease-in-out;
|
|
||||||
}
|
|
||||||
|
|
||||||
.homep-cover-img-2 {
|
|
||||||
background: #000 url(../../../public/images/foto2.jpg) no-repeat 50% fixed;
|
|
||||||
//transition: background-image 1s ease-in-out;
|
|
||||||
}
|
|
||||||
|
|
||||||
.homep-cover-img-3 {
|
|
||||||
background: #000 url(../../../public/images/foto3.jpg) no-repeat 50% fixed;
|
|
||||||
//transition: background-image 1s ease-in-out;
|
|
||||||
}
|
|
||||||
|
|
||||||
.homep-cover-img.hide-filter:before {
|
|
||||||
opacity: 0
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing__footer-icons {
|
|
||||||
font-size: 1.75rem
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing__footer-icons a {
|
|
||||||
margin: 0 .5rem .5rem;
|
|
||||||
text-decoration: none;
|
|
||||||
outline: 0;
|
|
||||||
color: $textcol;
|
|
||||||
transition: color .28s
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing__footer-icons a:hover {
|
|
||||||
color: $textcol_scuro;
|
|
||||||
}
|
|
||||||
|
|
||||||
.doc-img {
|
|
||||||
max-width: 100%;
|
|
||||||
}
|
|
||||||
|
|
||||||
.mylist {
|
|
||||||
background: #3fdaff;
|
|
||||||
padding-left: 1.25rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.clgutter {
|
|
||||||
margin-top: 1.25rem;
|
|
||||||
padding: .62rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.carousel_img_3 {
|
|
||||||
//background-image: url(../../public/images/cibo_sano.jpg);
|
|
||||||
background-size: cover !important;
|
|
||||||
background-position: 50% center !important;
|
|
||||||
background-repeat: no-repeat !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
@media (max-width: 718px) {
|
|
||||||
// PER VERSIONE MOBILE
|
|
||||||
|
|
||||||
.landing__hero {
|
|
||||||
text-align: center
|
|
||||||
}
|
|
||||||
.landing__header {
|
|
||||||
height: 7vh
|
|
||||||
}
|
|
||||||
.clgutter {
|
|
||||||
margin-top: 0;
|
|
||||||
padding: 0;
|
|
||||||
}
|
|
||||||
.landing__hero .text-h1, h1 {
|
|
||||||
font-size: 2rem;
|
|
||||||
line-height: 2.05rem;
|
|
||||||
margin-bottom: 1.25rem
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing > section.padding {
|
|
||||||
padding: 2.5rem 1rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing > section.padding_testo {
|
|
||||||
padding-top: 1.25rem;
|
|
||||||
padding-bottom: 1rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing > section.padding_gallery {
|
|
||||||
padding-top: 3.125rem;
|
|
||||||
padding-bottom: 5.625rem;
|
|
||||||
|
|
||||||
max-width: 800px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing > section.padding_gallery > div {
|
|
||||||
padding-top: 3.125rem;
|
|
||||||
padding-bottom: 5.625rem;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing__features h4, .landing__features h6 {
|
|
||||||
margin: 1.25rem 0
|
|
||||||
}
|
|
||||||
|
|
||||||
h4 {
|
|
||||||
line-height: 1.4;
|
|
||||||
text-shadow: 0.25rem 0.25rem 0.5rem $grayshadow;
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing .feature-item {
|
|
||||||
text-align: center;
|
|
||||||
margin-top: 1.25rem;
|
|
||||||
}
|
|
||||||
.landing__hero-content {
|
|
||||||
padding-bottom: 11.25rem;
|
|
||||||
}
|
|
||||||
.landing__hero2-content {
|
|
||||||
padding-bottom: 7.25rem;
|
|
||||||
}
|
|
||||||
.landing__hero-btns {
|
|
||||||
-webkit-box-pack: center;
|
|
||||||
-ms-flex-pack: center;
|
|
||||||
justify-content: center
|
|
||||||
}
|
|
||||||
|
|
||||||
.q-col-gutter-sm {
|
|
||||||
padding: .625rem .315rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.text-subtitle1 {
|
|
||||||
font-size: 1.25rem;
|
|
||||||
}
|
|
||||||
.text-vers {
|
|
||||||
font-size: 0.6rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.carousel_img_3 {
|
|
||||||
//background-image: url(../../public/images/cibo_sano.jpg);
|
|
||||||
background-size: 620px 620px !important;
|
|
||||||
background-position: 50% top !important;
|
|
||||||
background-repeat: no-repeat !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
.custom-caption {
|
|
||||||
text-align: center;
|
|
||||||
padding: .75rem;
|
|
||||||
color: $textcol;
|
|
||||||
background-color: rgba(0, 0, 0, .3);
|
|
||||||
}
|
|
||||||
|
|
||||||
.sfondo-grigio {
|
|
||||||
padding: 1rem;
|
|
||||||
color: $textcol;
|
|
||||||
background-color: rgba(0, 0, 0, .35);
|
|
||||||
}
|
|
||||||
|
|
||||||
.mycontacts {
|
|
||||||
color: gray;
|
|
||||||
letter-spacing: 0.078rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.mycontacts_title {
|
|
||||||
text-shadow: 0.125rem 0.125rem 0.125rem #555;
|
|
||||||
font-weight: bold;
|
|
||||||
color: #999;
|
|
||||||
letter-spacing: 0.125rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.mycontacts_text {
|
|
||||||
color: #999;
|
|
||||||
letter-spacing: 0.093rem;
|
|
||||||
}
|
|
||||||
@@ -1,54 +0,0 @@
|
|||||||
import { defineComponent, ref, onMounted, watch, computed } from 'vue'
|
|
||||||
|
|
||||||
import { useGlobalStore } from '@store/globalStore'
|
|
||||||
import { useRoute } from 'vue-router'
|
|
||||||
import { useUserStore } from '@store/UserStore'
|
|
||||||
|
|
||||||
import { Logo } from '@/components/logo'
|
|
||||||
|
|
||||||
import { LandingFooter } from '@/components/LandingFooter'
|
|
||||||
import { CMyPage } from '@/components/CMyPage/index'
|
|
||||||
|
|
||||||
import { tools } from '@src/store/Modules/tools'
|
|
||||||
import { static_data } from '@src/db/static_data'
|
|
||||||
import { toolsext } from '@src/store/Modules/toolsext'
|
|
||||||
import { Screen } from 'quasar'
|
|
||||||
import { CCardCarousel, CEventsCalendar, CMyElem, COpenStreetMap } from '@components'
|
|
||||||
import MixinBase from '@src/mixins/mixin-base'
|
|
||||||
import { firstimagehome } from '@src/db/static_data'
|
|
||||||
import MixinMetaTags from '@/mixins/mixin-metatags'
|
|
||||||
|
|
||||||
export default defineComponent({
|
|
||||||
name: 'home_kolibrilab',
|
|
||||||
components: { Logo, LandingFooter, CMyPage, CMyElem },
|
|
||||||
|
|
||||||
setup() {
|
|
||||||
const userStore = useUserStore()
|
|
||||||
const globalStore = useGlobalStore()
|
|
||||||
|
|
||||||
const { setValDb, getValDb } = MixinBase()
|
|
||||||
|
|
||||||
function getheightgallery() {
|
|
||||||
if (tools.isMobile())
|
|
||||||
return '400px'
|
|
||||||
else
|
|
||||||
return '600px'
|
|
||||||
}
|
|
||||||
|
|
||||||
function created() {
|
|
||||||
//
|
|
||||||
}
|
|
||||||
|
|
||||||
created()
|
|
||||||
|
|
||||||
return {
|
|
||||||
tools,
|
|
||||||
toolsext,
|
|
||||||
static_data,
|
|
||||||
getheightgallery,
|
|
||||||
getValDb,
|
|
||||||
globalStore,
|
|
||||||
}
|
|
||||||
},
|
|
||||||
})
|
|
||||||
|
|
||||||
@@ -1,18 +0,0 @@
|
|||||||
<template>
|
|
||||||
<q-page>
|
|
||||||
<CMyPage title="Home">
|
|
||||||
<span v-for="(myelem, ind) in globalStore.getMyElems('home')" :key="ind">
|
|
||||||
<CMyElem v-if="myelem.active" :myelem="myelem" path="home">
|
|
||||||
|
|
||||||
</CMyElem>
|
|
||||||
</span>
|
|
||||||
</CMyPage>
|
|
||||||
</q-page>
|
|
||||||
</template>
|
|
||||||
|
|
||||||
<script lang="ts" src="./home_kolibrilab.ts">
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<style lang="scss" scoped>
|
|
||||||
@import './home_kolibrilab.scss';
|
|
||||||
</style>
|
|
||||||
@@ -1,54 +0,0 @@
|
|||||||
import { defineComponent, ref, onMounted, watch, computed } from 'vue'
|
|
||||||
|
|
||||||
import { useGlobalStore } from '@store/globalStore'
|
|
||||||
import { useRoute } from 'vue-router'
|
|
||||||
import { useUserStore } from '@store/UserStore'
|
|
||||||
|
|
||||||
import { Logo } from '@/components/logo'
|
|
||||||
|
|
||||||
import { LandingFooter } from '@/components/LandingFooter'
|
|
||||||
import { CMyPage } from '@/components/CMyPage/index'
|
|
||||||
|
|
||||||
import { tools } from '@src/store/Modules/tools'
|
|
||||||
import { static_data } from '@src/db/static_data'
|
|
||||||
import { toolsext } from '@src/store/Modules/toolsext'
|
|
||||||
import { Screen } from 'quasar'
|
|
||||||
import { CCardCarousel, CEventsCalendar, CMyElem, COpenStreetMap } from '@components'
|
|
||||||
import MixinBase from '@src/mixins/mixin-base'
|
|
||||||
import { firstimagehome } from '@src/db/static_data'
|
|
||||||
import MixinMetaTags from '@/mixins/mixin-metatags'
|
|
||||||
|
|
||||||
export default defineComponent({
|
|
||||||
name: 'home_kolibrilab',
|
|
||||||
components: { Logo, LandingFooter, CMyPage, CMyElem },
|
|
||||||
|
|
||||||
setup() {
|
|
||||||
const userStore = useUserStore()
|
|
||||||
const globalStore = useGlobalStore()
|
|
||||||
|
|
||||||
const { setValDb, getValDb } = MixinBase()
|
|
||||||
|
|
||||||
function getheightgallery() {
|
|
||||||
if (tools.isMobile())
|
|
||||||
return '400px'
|
|
||||||
else
|
|
||||||
return '600px'
|
|
||||||
}
|
|
||||||
|
|
||||||
function created() {
|
|
||||||
//
|
|
||||||
}
|
|
||||||
|
|
||||||
created()
|
|
||||||
|
|
||||||
return {
|
|
||||||
tools,
|
|
||||||
toolsext,
|
|
||||||
static_data,
|
|
||||||
getheightgallery,
|
|
||||||
getValDb,
|
|
||||||
globalStore,
|
|
||||||
}
|
|
||||||
},
|
|
||||||
})
|
|
||||||
|
|
||||||
@@ -1,18 +0,0 @@
|
|||||||
<template>
|
|
||||||
<q-page>
|
|
||||||
<CMyPage title="Home">
|
|
||||||
<span v-for="(myelem, ind) in globalStore.myelems" :key="ind">
|
|
||||||
<CMyElem v-if="myelem.active" :myelem="myelem">
|
|
||||||
|
|
||||||
</CMyElem>
|
|
||||||
</span>
|
|
||||||
</CMyPage>
|
|
||||||
</q-page>
|
|
||||||
</template>
|
|
||||||
|
|
||||||
<script lang="ts" src="./home_kolibrilab.ts">
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<style lang="scss" scoped>
|
|
||||||
@import './home_kolibrilab.scss';
|
|
||||||
</style>
|
|
||||||
@@ -18,6 +18,7 @@
|
|||||||
"fix": "eslint --ext .ts,.vue --ignore-path .gitignore ./ --fix > file.out.txt",
|
"fix": "eslint --ext .ts,.vue --ignore-path .gitignore ./ --fix > file.out.txt",
|
||||||
"pwa": "NODE_ENV=development NODE_OPTIONS=--max_old_space_size=4096 DEBUG=v8:* quasar dev -m pwa",
|
"pwa": "NODE_ENV=development NODE_OPTIONS=--max_old_space_size=4096 DEBUG=v8:* quasar dev -m pwa",
|
||||||
"spa": "NODE_ENV=development NODE_OPTIONS=--max_old_space_size=4096 DEBUG=v8:* quasar dev -m spa",
|
"spa": "NODE_ENV=development NODE_OPTIONS=--max_old_space_size=4096 DEBUG=v8:* quasar dev -m spa",
|
||||||
|
"spanorefresh": "NODE_ENV=development NODE_OPTIONS=--max_old_space_size=4096 DEBUG=v8:* quasar dev -m spa",
|
||||||
"test": "echo \"No test specified\" && exit 0",
|
"test": "echo \"No test specified\" && exit 0",
|
||||||
"generate-sw": "workbox generateSW workbox-config.js"
|
"generate-sw": "workbox generateSW workbox-config.js"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -105,7 +105,7 @@ let idbKeyval = (() => {
|
|||||||
});
|
});
|
||||||
return req.result;
|
return req.result;
|
||||||
},
|
},
|
||||||
async set(key, value) {
|
set(key, value) {
|
||||||
let req;
|
let req;
|
||||||
/*await withStore('readwrite', 'keyval', store => {
|
/*await withStore('readwrite', 'keyval', store => {
|
||||||
req = store.put(value, key);
|
req = store.put(value, key);
|
||||||
|
|||||||
@@ -149,6 +149,7 @@ module.exports = configure((ctx) => ({
|
|||||||
https: false,
|
https: false,
|
||||||
port: 8090,
|
port: 8090,
|
||||||
open: false, // opens browser window automatically
|
open: false, // opens browser window automatically
|
||||||
|
// vueDevtools: true,
|
||||||
},
|
},
|
||||||
|
|
||||||
// https://v2.quasar.dev/quasar-cli/quasar-conf-js#Property%3A-framework
|
// https://v2.quasar.dev/quasar-cli/quasar-conf-js#Property%3A-framework
|
||||||
|
|||||||
@@ -1206,7 +1206,7 @@ export const shared_consts = {
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
value: 35,
|
value: 35,
|
||||||
label: 'Immagine da Caricare',
|
label: 'Img da Caricare',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
value: 40,
|
value: 40,
|
||||||
|
|||||||
@@ -2,7 +2,7 @@ import {
|
|||||||
defineComponent, onMounted, PropType, ref, toRef, watch,
|
defineComponent, onMounted, PropType, ref, toRef, watch,
|
||||||
} from 'vue'
|
} from 'vue'
|
||||||
|
|
||||||
import { ILabelValue, IMyElem, IMyPage, IOperators } from '@src/model'
|
import { IImgGallery, ILabelValue, IMyCard, IMyElem, IMyPage, IOperators } from '@src/model'
|
||||||
import { useGlobalStore } from '@store/globalStore'
|
import { useGlobalStore } from '@store/globalStore'
|
||||||
|
|
||||||
import { CImgTitle } from '../CImgTitle/index'
|
import { CImgTitle } from '../CImgTitle/index'
|
||||||
@@ -26,13 +26,15 @@ import { useQuasar } from 'quasar'
|
|||||||
import { useI18n } from '@/boot/i18n'
|
import { useI18n } from '@/boot/i18n'
|
||||||
import { emitKeypressEvents } from 'readline'
|
import { emitKeypressEvents } from 'readline'
|
||||||
import { costanti } from '@costanti'
|
import { costanti } from '@costanti'
|
||||||
|
import objectId from '@src/js/objectId'
|
||||||
|
|
||||||
export default defineComponent({
|
export default defineComponent({
|
||||||
name: 'CMyEditElem',
|
name: 'CMyEditElem',
|
||||||
components: { CImgTitle, CTitle, LandingFooter, CEventsCalendar,
|
components: {
|
||||||
|
CImgTitle, CTitle, LandingFooter, CEventsCalendar,
|
||||||
CCardCarousel, COpenStreetMap, CMyPage, CMyPageIntro, CMyEditor, CMyFieldRec,
|
CCardCarousel, COpenStreetMap, CMyPage, CMyPageIntro, CMyEditor, CMyFieldRec,
|
||||||
CSelectColor, CSelectFontSize },
|
CSelectColor, CSelectFontSize
|
||||||
|
},
|
||||||
emits: ['saveElem'],
|
emits: ['saveElem'],
|
||||||
props: {
|
props: {
|
||||||
myelem: {
|
myelem: {
|
||||||
@@ -74,7 +76,7 @@ export default defineComponent({
|
|||||||
const elemChanged = ref(false)
|
const elemChanged = ref(false)
|
||||||
const enableAdd = ref(true)
|
const enableAdd = ref(true)
|
||||||
|
|
||||||
const neworder = ref(<number|undefined>0)
|
const neworder = ref(<number | undefined>0)
|
||||||
|
|
||||||
const myel = toRef(props, 'myelem')
|
const myel = toRef(props, 'myelem')
|
||||||
const newtype = ref(<any>'')
|
const newtype = ref(<any>'')
|
||||||
@@ -87,13 +89,6 @@ export default defineComponent({
|
|||||||
return globalStore.disciplines.filter((rec: any) => rec.showinhome)
|
return globalStore.disciplines.filter((rec: any) => rec.showinhome)
|
||||||
}
|
}
|
||||||
|
|
||||||
function getheightgallery() {
|
|
||||||
if (tools.isMobile())
|
|
||||||
return '400px'
|
|
||||||
else
|
|
||||||
return '600px'
|
|
||||||
}
|
|
||||||
|
|
||||||
function saveElem(exit?: boolean) {
|
function saveElem(exit?: boolean) {
|
||||||
// Save Elem record
|
// Save Elem record
|
||||||
const myelem = props.myelem
|
const myelem = props.myelem
|
||||||
@@ -165,7 +160,7 @@ export default defineComponent({
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function modifElem(value: any) {
|
function modifElem() {
|
||||||
disableSave.value = false
|
disableSave.value = false
|
||||||
elemChanged.value = true
|
elemChanged.value = true
|
||||||
}
|
}
|
||||||
@@ -174,7 +169,7 @@ export default defineComponent({
|
|||||||
neworder.value = props.myelem.order
|
neworder.value = props.myelem.order
|
||||||
|
|
||||||
arrPages.value = []
|
arrPages.value = []
|
||||||
arrPages.value.push({label: '[Vuoto]', path: ''})
|
arrPages.value.push({ label: '[Vuoto]', path: '' })
|
||||||
for (const page of globalStore.mypage) {
|
for (const page of globalStore.mypage) {
|
||||||
|
|
||||||
const rec = {
|
const rec = {
|
||||||
@@ -198,8 +193,9 @@ export default defineComponent({
|
|||||||
function addNewCard() {
|
function addNewCard() {
|
||||||
if (!myel.value.listcards)
|
if (!myel.value.listcards)
|
||||||
myel.value.listcards = []
|
myel.value.listcards = []
|
||||||
myel.value.listcards.push({ imagefile: '', alt: '', description: '' })
|
|
||||||
modifElem(true)
|
myel.value.listcards.push({ _id: objectId(), imagefile: '', alt: '', description: '' })
|
||||||
|
modifElem()
|
||||||
}
|
}
|
||||||
|
|
||||||
function getClass() {
|
function getClass() {
|
||||||
@@ -222,13 +218,37 @@ export default defineComponent({
|
|||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function delRecCard(idcard: string, myel: IMyElem) {
|
||||||
|
//
|
||||||
|
if (myel.listcards)
|
||||||
|
myel.listcards = myel.listcards.filter((card: IMyCard) => card._id !== idcard)
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
function saveCard(recpass: IMyCard, myval: any) {
|
||||||
|
if (props.myelem.type === shared_consts.ELEMTYPE.CARD) {
|
||||||
|
if (props.myelem.listcards) {
|
||||||
|
props.myelem.listcards.forEach((rec: IMyCard) => {
|
||||||
|
if (recpass._id === rec._id) {
|
||||||
|
rec.imagefile = myval
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
modifElem()
|
||||||
|
}
|
||||||
|
|
||||||
|
function updateElem(myvalue: any) {
|
||||||
|
myel.value = myvalue
|
||||||
|
modifElem()
|
||||||
|
}
|
||||||
|
|
||||||
onMounted(mounted)
|
onMounted(mounted)
|
||||||
|
|
||||||
return {
|
return {
|
||||||
tools,
|
tools,
|
||||||
shared_consts,
|
shared_consts,
|
||||||
getArrDisciplines,
|
getArrDisciplines,
|
||||||
getheightgallery,
|
|
||||||
slide,
|
slide,
|
||||||
slide2,
|
slide2,
|
||||||
animare,
|
animare,
|
||||||
@@ -253,6 +273,9 @@ export default defineComponent({
|
|||||||
addNewCard,
|
addNewCard,
|
||||||
arrPages,
|
arrPages,
|
||||||
costanti,
|
costanti,
|
||||||
|
delRecCard,
|
||||||
|
saveCard,
|
||||||
|
updateElem,
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|||||||
@@ -7,14 +7,9 @@
|
|||||||
(!myel.active ? ` clEditNotActive` : ``)
|
(!myel.active ? ` clEditNotActive` : ``)
|
||||||
"
|
"
|
||||||
>
|
>
|
||||||
<div>
|
<div v-if="!!myel.type">
|
||||||
<q-bar v-if="enableEdit" dense class="bg-blue-1 q-px-sm">
|
<q-bar v-if="enableEdit" dense class="bg-blue-1 q-px-sm">
|
||||||
<q-toggle
|
<q-toggle v-model="myel.active" color="positive" icon="fas fa-eye">
|
||||||
left-label="Attiva"
|
|
||||||
v-model="myel.active"
|
|
||||||
color="positive"
|
|
||||||
icon="fas fa-eye"
|
|
||||||
>
|
|
||||||
</q-toggle>
|
</q-toggle>
|
||||||
<!--<q-toggle v-if="tools.isManager()"
|
<!--<q-toggle v-if="tools.isManager()"
|
||||||
v-model="enableAdd"
|
v-model="enableAdd"
|
||||||
@@ -74,7 +69,27 @@
|
|||||||
>
|
>
|
||||||
</q-btn>
|
</q-btn>
|
||||||
</q-bar>
|
</q-bar>
|
||||||
<div class="justify-center q-gutter-xs row">
|
<div class="row">
|
||||||
|
<q-input
|
||||||
|
label="Width:"
|
||||||
|
@update:model-value="modifElem"
|
||||||
|
v-model="myel.widthimg"
|
||||||
|
filled
|
||||||
|
dense
|
||||||
|
v-on:keyup.enter="saveElem"
|
||||||
|
>
|
||||||
|
</q-input>
|
||||||
|
<q-input
|
||||||
|
label="Height:"
|
||||||
|
@update:model-value="modifElem"
|
||||||
|
v-model="myel.heightimg"
|
||||||
|
filled
|
||||||
|
dense
|
||||||
|
v-on:keyup.enter="saveElem"
|
||||||
|
>
|
||||||
|
</q-input>
|
||||||
|
</div>
|
||||||
|
<div class="justify-center row q-ma-xs">
|
||||||
<q-btn
|
<q-btn
|
||||||
dense
|
dense
|
||||||
v-if="enableEdit && !disableSave"
|
v-if="enableEdit && !disableSave"
|
||||||
@@ -171,6 +186,16 @@
|
|||||||
v-if="myel.type === shared_consts.ELEMTYPE.CARD"
|
v-if="myel.type === shared_consts.ELEMTYPE.CARD"
|
||||||
:class="myel.span ? '' : ''"
|
:class="myel.span ? '' : ''"
|
||||||
>
|
>
|
||||||
|
<div class="row">
|
||||||
|
<q-input
|
||||||
|
label="Classe Card:"
|
||||||
|
@update:model-value="modifElem"
|
||||||
|
v-model="myel.class3"
|
||||||
|
filled
|
||||||
|
v-on:keyup.enter="saveElem"
|
||||||
|
>
|
||||||
|
</q-input>
|
||||||
|
</div>
|
||||||
<q-btn
|
<q-btn
|
||||||
rounded
|
rounded
|
||||||
dense
|
dense
|
||||||
@@ -181,28 +206,48 @@
|
|||||||
>
|
>
|
||||||
</q-btn>
|
</q-btn>
|
||||||
<div v-for="(rec, ind) in myel.listcards" :key="ind">
|
<div v-for="(rec, ind) in myel.listcards" :key="ind">
|
||||||
<div v-if="enableEdit" class="column">
|
<div v-if="enableEdit" class="column bordered q-ma-xs">
|
||||||
|
<q-bar class="bg-primary text-white">
|
||||||
|
Card {{ ind + 1 }}
|
||||||
|
<q-space />
|
||||||
|
<q-btn
|
||||||
|
icon="fas fa-trash-alt"
|
||||||
|
color="negative"
|
||||||
|
dense
|
||||||
|
flat
|
||||||
|
size="sm"
|
||||||
|
@click="delRecCard(rec._id, myel)"
|
||||||
|
>
|
||||||
|
</q-btn>
|
||||||
|
</q-bar>
|
||||||
|
|
||||||
|
<CSelectImage
|
||||||
|
:title="tools.getTitleGall()"
|
||||||
|
:directory="tools.getDirectoryGall(myvalue, 'imgcards')"
|
||||||
|
:imgGall="[myvalue]"
|
||||||
|
:edit="true"
|
||||||
|
:canModify="true"
|
||||||
|
:isInModif="true"
|
||||||
|
@update:imgGall="updateElem"
|
||||||
|
@showandsave="Savedb">
|
||||||
|
</CSelectImage>
|
||||||
|
|
||||||
<CMyFieldRec
|
<CMyFieldRec
|
||||||
title="Lista Immagini:"
|
title="Immagine:"
|
||||||
table="myelems"
|
table="imgcards"
|
||||||
:id="myel._id"
|
:id="rec._id"
|
||||||
:rec="myel"
|
:rec="rec"
|
||||||
field="listcards"
|
field="imagefile"
|
||||||
@update:model-value="modifElem"
|
@update:model-value="modifElem"
|
||||||
|
@save="saveCard"
|
||||||
:canEdit="true"
|
:canEdit="true"
|
||||||
:canModify="true"
|
:canModify="true"
|
||||||
|
:nosaveToDb="true"
|
||||||
|
:path="myel.path"
|
||||||
|
:fieldtype="costanti.FieldType.imgcard"
|
||||||
>
|
>
|
||||||
</CMyFieldRec>
|
</CMyFieldRec>
|
||||||
<q-input
|
|
||||||
label="Immagine:"
|
|
||||||
dense
|
|
||||||
class="fa-border"
|
|
||||||
@update:model-value="modifElem"
|
|
||||||
v-model="rec.imagefile"
|
|
||||||
filled
|
|
||||||
v-on:keyup.enter="saveElem"
|
|
||||||
>
|
|
||||||
</q-input>
|
|
||||||
<div v-if="enableEdit" class="row">
|
<div v-if="enableEdit" class="row">
|
||||||
<q-input
|
<q-input
|
||||||
dense
|
dense
|
||||||
@@ -215,6 +260,17 @@
|
|||||||
v-on:keyup.enter="saveElem"
|
v-on:keyup.enter="saveElem"
|
||||||
>
|
>
|
||||||
</q-input>
|
</q-input>
|
||||||
|
<q-input
|
||||||
|
dense
|
||||||
|
style="min-width: 100px"
|
||||||
|
label="Style:"
|
||||||
|
class="fa-border"
|
||||||
|
@update:model-value="modifElem"
|
||||||
|
v-model="rec.style"
|
||||||
|
filled
|
||||||
|
v-on:keyup.enter="saveElem"
|
||||||
|
>
|
||||||
|
</q-input>
|
||||||
<CSelectColor
|
<CSelectColor
|
||||||
v-if="enableEdit"
|
v-if="enableEdit"
|
||||||
style="min-width: 100px"
|
style="min-width: 100px"
|
||||||
@@ -375,30 +431,9 @@
|
|||||||
@update:model-value="modifElem"
|
@update:model-value="modifElem"
|
||||||
:canEdit="true"
|
:canEdit="true"
|
||||||
:canModify="true"
|
:canModify="true"
|
||||||
:type="costanti.FieldType.images"
|
:fieldtype="costanti.FieldType.image"
|
||||||
>
|
>
|
||||||
</CMyFieldRec>
|
</CMyFieldRec>
|
||||||
|
|
||||||
<div class="row">
|
|
||||||
<q-input
|
|
||||||
label="Width:"
|
|
||||||
@update:model-value="modifElem"
|
|
||||||
v-model="myel.widthimg"
|
|
||||||
filled
|
|
||||||
dense
|
|
||||||
v-on:keyup.enter="saveElem"
|
|
||||||
>
|
|
||||||
</q-input>
|
|
||||||
<q-input
|
|
||||||
label="Height:"
|
|
||||||
@update:model-value="modifElem"
|
|
||||||
v-model="myel.heightimg"
|
|
||||||
filled
|
|
||||||
dense
|
|
||||||
v-on:keyup.enter="saveElem"
|
|
||||||
>
|
|
||||||
</q-input>
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
@@ -421,7 +456,7 @@
|
|||||||
@update:model-value="modifElem"
|
@update:model-value="modifElem"
|
||||||
:canEdit="true"
|
:canEdit="true"
|
||||||
:canModify="true"
|
:canModify="true"
|
||||||
:type="costanti.FieldType.images"
|
:fieldtype="costanti.FieldType.image"
|
||||||
>
|
>
|
||||||
</CMyFieldRec>
|
</CMyFieldRec>
|
||||||
<div class="row">
|
<div class="row">
|
||||||
|
|||||||
@@ -16,7 +16,8 @@ export default defineComponent({
|
|||||||
},
|
},
|
||||||
value: {
|
value: {
|
||||||
type: String,
|
type: String,
|
||||||
required: true,
|
required: false,
|
||||||
|
default: '',
|
||||||
},
|
},
|
||||||
myclass: {
|
myclass: {
|
||||||
type: String,
|
type: String,
|
||||||
|
|||||||
@@ -462,6 +462,9 @@ body.mobile .landing:before {
|
|||||||
border: #11f609 solid 2px;
|
border: #11f609 solid 2px;
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
}
|
}
|
||||||
|
.selectedElem {
|
||||||
|
border: #200e96 solid 3px !important;
|
||||||
|
}
|
||||||
|
|
||||||
.align_center {
|
.align_center {
|
||||||
text-align: center;
|
text-align: center;
|
||||||
|
|||||||
@@ -28,15 +28,21 @@ import { useI18n } from '@/boot/i18n'
|
|||||||
|
|
||||||
export default defineComponent({
|
export default defineComponent({
|
||||||
name: 'CMyElem',
|
name: 'CMyElem',
|
||||||
components: { CImgTitle, CTitle, LandingFooter, CEventsCalendar,
|
components: {
|
||||||
|
CImgTitle, CTitle, LandingFooter, CEventsCalendar,
|
||||||
CCardCarousel, COpenStreetMap, CMyPage, CMyPageIntro, CMyEditor, CMyFieldRec,
|
CCardCarousel, COpenStreetMap, CMyPage, CMyPageIntro, CMyEditor, CMyFieldRec,
|
||||||
CSelectColor, CSelectFontSize },
|
CSelectColor, CSelectFontSize
|
||||||
|
},
|
||||||
emits: ['selElemClick'],
|
emits: ['selElemClick'],
|
||||||
props: {
|
props: {
|
||||||
myelem: {
|
myelem: {
|
||||||
type: Object as PropType<IMyElem>,
|
type: Object as PropType<IMyElem>,
|
||||||
required: true,
|
required: true,
|
||||||
},
|
},
|
||||||
|
selElem: {
|
||||||
|
type: Object as PropType<IMyElem>,
|
||||||
|
required: false,
|
||||||
|
},
|
||||||
path: {
|
path: {
|
||||||
type: String,
|
type: String,
|
||||||
required: false,
|
required: false,
|
||||||
@@ -70,7 +76,7 @@ export default defineComponent({
|
|||||||
const enableEdit = ref(false)
|
const enableEdit = ref(false)
|
||||||
const enableAdd = ref(true)
|
const enableAdd = ref(true)
|
||||||
|
|
||||||
const neworder = ref(<number|undefined>0)
|
const neworder = ref(<number | undefined>0)
|
||||||
|
|
||||||
const myel = toRef(props, 'myelem')
|
const myel = toRef(props, 'myelem')
|
||||||
const newtype = ref(<any>'')
|
const newtype = ref(<any>'')
|
||||||
@@ -157,7 +163,7 @@ export default defineComponent({
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function modifElem(value: any) {
|
function modifElem() {
|
||||||
disableSave.value = false
|
disableSave.value = false
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -171,6 +177,7 @@ export default defineComponent({
|
|||||||
function clickOnElem() {
|
function clickOnElem() {
|
||||||
if (props.editOn) {
|
if (props.editOn) {
|
||||||
enableEdit.value = true
|
enableEdit.value = true
|
||||||
|
console.log('selElemClick', props.myelem)
|
||||||
emit('selElemClick', props.myelem)
|
emit('selElemClick', props.myelem)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -188,13 +195,21 @@ export default defineComponent({
|
|||||||
if (props.myelem.class2)
|
if (props.myelem.class2)
|
||||||
mycl += ' ' + props.myelem.class2
|
mycl += ' ' + props.myelem.class2
|
||||||
|
|
||||||
|
if (props.selElem && props.editOn) {
|
||||||
|
if (props.myelem._id === props.selElem._id)
|
||||||
|
mycl += ' selectedElem'
|
||||||
|
}
|
||||||
|
|
||||||
return mycl
|
return mycl
|
||||||
}
|
}
|
||||||
|
|
||||||
function getImgFileByElem(elem: IMyElem, reccard?: IMyCard) {
|
function getImgFileByElem(elem: IMyElem, reccard?: IMyCard) {
|
||||||
if (elem) {
|
if (elem) {
|
||||||
if (elem.type === shared_consts.ELEMTYPE.CARD) {
|
if (elem.type === shared_consts.ELEMTYPE.CARD) {
|
||||||
return 'upload/pages/' + elem.path + '/' + reccard!.imagefile
|
if (reccard?.imagefile)
|
||||||
|
return 'upload/pages/' + elem.path + '/' + reccard.imagefile
|
||||||
|
else
|
||||||
|
return ''
|
||||||
} else if (elem.type === shared_consts.ELEMTYPE.IMAGE) {
|
} else if (elem.type === shared_consts.ELEMTYPE.IMAGE) {
|
||||||
return 'upload/pages/' + elem.path + '/' + elem.container
|
return 'upload/pages/' + elem.path + '/' + elem.container
|
||||||
} else {
|
} else {
|
||||||
|
|||||||
@@ -25,8 +25,8 @@
|
|||||||
@click="clickOnElem"
|
@click="clickOnElem"
|
||||||
>
|
>
|
||||||
<div v-for="(rec, ind) in myel.listcards" :key="ind" >
|
<div v-for="(rec, ind) in myel.listcards" :key="ind" >
|
||||||
<q-card class="my-card center_img" flat bordered>
|
<q-card :class="`my-card center_img bordered ` + myel.class3"
|
||||||
rec: {{rec}}
|
:style="rec.style">
|
||||||
<q-img :src="getImgFileByElem(myel, rec)" />
|
<q-img :src="getImgFileByElem(myel, rec)" />
|
||||||
<q-card-section>
|
<q-card-section>
|
||||||
<div :class="` ` + rec.size" :style="`color: ` + rec.color">
|
<div :class="` ` + rec.size" :style="`color: ` + rec.color">
|
||||||
@@ -221,7 +221,7 @@
|
|||||||
</div>
|
</div>
|
||||||
<div v-else-if="myel.type === shared_consts.ELEMTYPE.CAROUSEL_IMGS">
|
<div v-else-if="myel.type === shared_consts.ELEMTYPE.CAROUSEL_IMGS">
|
||||||
<section
|
<section
|
||||||
class="maxwidth padding_gallery bg-white text-grey-10 text-center"
|
class="padding_gallery bg-white text-grey-10 text-center"
|
||||||
>
|
>
|
||||||
<div
|
<div
|
||||||
:class="myel.class + (editOn ? ` clEdit` : ``) + getClass()"
|
:class="myel.class + (editOn ? ` clEdit` : ``) + getClass()"
|
||||||
@@ -236,14 +236,15 @@
|
|||||||
:fit="myel.fit"
|
:fit="myel.fit"
|
||||||
:thumbnails="myel.parambool2"
|
:thumbnails="myel.parambool2"
|
||||||
infinite
|
infinite
|
||||||
:height="myel.height ? myel.height.toString() : 600"
|
:height="myel.heightimg ? myel.heightimg.toString() : tools.getheightgallery()"
|
||||||
>
|
>
|
||||||
|
|
||||||
<q-carousel-slide
|
<q-carousel-slide
|
||||||
v-for="(rec, index) in myel.list"
|
v-for="(rec, index) in myel.list"
|
||||||
:key="index"
|
:key="index"
|
||||||
:name="index"
|
:name="index"
|
||||||
:img-src="
|
:img-src="
|
||||||
getsrcbyimg(`upload/pages/` + path + `/` + rec.imagefile)
|
getsrcbyimg(`upload/pages/` + myel.path + `/` + rec.imagefile)
|
||||||
"
|
"
|
||||||
:alt="rec.alt"
|
:alt="rec.alt"
|
||||||
class="carousel_slide"
|
class="carousel_slide"
|
||||||
|
|||||||
@@ -96,7 +96,7 @@ export default defineComponent({
|
|||||||
default: null,
|
default: null,
|
||||||
},
|
},
|
||||||
mycol: {
|
mycol: {
|
||||||
type: Object as PropType<IColGridTable>,
|
type: Object as PropType<IColGridTable> | undefined,
|
||||||
required: false,
|
required: false,
|
||||||
default: () => {
|
default: () => {
|
||||||
return { name: '' }
|
return { name: '' }
|
||||||
@@ -142,16 +142,24 @@ export default defineComponent({
|
|||||||
}
|
}
|
||||||
|
|
||||||
function withBorder() {
|
function withBorder() {
|
||||||
return col.value.fieldtype !== costanti.FieldType.onlydate && col.value.fieldtype !== costanti.FieldType.date
|
if (col.value)
|
||||||
|
return col.value.fieldtype !== costanti.FieldType.onlydate && col.value.fieldtype !== costanti.FieldType.date
|
||||||
|
else
|
||||||
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
function mounted() {
|
function mounted() {
|
||||||
if (props.rec) {
|
if (props.rec) {
|
||||||
row.value = props.rec
|
row.value = props.rec
|
||||||
}
|
}
|
||||||
if (props.mycol.name !== '') {
|
if (props.mycol && props.mycol.name !== '') {
|
||||||
col.value = props.mycol
|
col.value = props.mycol
|
||||||
|
} else {
|
||||||
|
console.log('Tab = ', props.table, 'key=', props.mykey)
|
||||||
|
col.value = fieldsTable.getColByTable(props.table, props.mykey)
|
||||||
|
console.log('MYCOL = ', col.value)
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
onMounted(mounted)
|
onMounted(mounted)
|
||||||
|
|||||||
@@ -23,6 +23,7 @@
|
|||||||
<div :class="` q-ma-sm q-pa-sm col-grow popupedit `" :style="withBorder() ? `` : ``">
|
<div :class="` q-ma-sm q-pa-sm col-grow popupedit `" :style="withBorder() ? `` : ``">
|
||||||
|
|
||||||
<CMyPopupEdit
|
<CMyPopupEdit
|
||||||
|
:fielddb="true"
|
||||||
v-bind="$attrs"
|
v-bind="$attrs"
|
||||||
:rec="rec"
|
:rec="rec"
|
||||||
:isrec="!!rec"
|
:isrec="!!rec"
|
||||||
@@ -43,7 +44,7 @@
|
|||||||
:canEdit="true"
|
:canEdit="true"
|
||||||
:id="id"
|
:id="id"
|
||||||
:idmain="idmain"
|
:idmain="idmain"
|
||||||
:mycol="col"
|
:mycol="col ? col : {}"
|
||||||
:tablesel="tablesel"
|
:tablesel="tablesel"
|
||||||
:pickup="pickup"
|
:pickup="pickup"
|
||||||
v-model:row="row"
|
v-model:row="row"
|
||||||
|
|||||||
@@ -12,6 +12,7 @@ import MixinBase from '@/mixins/mixin-base'
|
|||||||
|
|
||||||
export default defineComponent({
|
export default defineComponent({
|
||||||
name: 'CMyFieldRec',
|
name: 'CMyFieldRec',
|
||||||
|
emits: ['save'],
|
||||||
props: {
|
props: {
|
||||||
table: {
|
table: {
|
||||||
type: String,
|
type: String,
|
||||||
@@ -95,7 +96,12 @@ export default defineComponent({
|
|||||||
tupe: String,
|
tupe: String,
|
||||||
required: false,
|
required: false,
|
||||||
default: '',
|
default: '',
|
||||||
}
|
},
|
||||||
|
nosaveToDb: {
|
||||||
|
type: Boolean,
|
||||||
|
required: false,
|
||||||
|
default: false,
|
||||||
|
},
|
||||||
},
|
},
|
||||||
components: { CMyPopupEdit },
|
components: { CMyPopupEdit },
|
||||||
setup(props, { emit }) {
|
setup(props, { emit }) {
|
||||||
@@ -143,15 +149,23 @@ export default defineComponent({
|
|||||||
mysubkey.value = arrk[1]
|
mysubkey.value = arrk[1]
|
||||||
if (arrk.length > 2)
|
if (arrk.length > 2)
|
||||||
mysubsubkey.value = arrk[2]
|
mysubsubkey.value = arrk[2]
|
||||||
|
else
|
||||||
|
mykey.value = props.field
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function showandsel(row: any, col: any, newval: any, valinitial: any) {
|
function showandsel(row: any, col: any, newval: any, valinitial: any) {
|
||||||
console.log('showandsel CMyFieldDb', row, col, newval)
|
// console.log('showandsel CMyFieldDb', row, col, newval)
|
||||||
|
emit('save', props.rec, newval)
|
||||||
|
|
||||||
|
if (props.nosaveToDb)
|
||||||
|
return
|
||||||
|
|
||||||
|
|
||||||
if (newval !== valinitial)
|
if (newval !== valinitial)
|
||||||
setValDb($q, mykey.value, newval, props.fieldtype || col.fieldtype, false, props.table, mysubkey.value, props.id, props.indrec, mysubsubkey.value, props.specialField)
|
setValDb($q, mykey.value, newval, props.fieldtype || col.fieldtype, false, props.table, mysubkey.value, props.id, props.indrec, mysubsubkey.value, props.specialField)
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function withBorder() {
|
function withBorder() {
|
||||||
|
|||||||
@@ -18,6 +18,7 @@
|
|||||||
</q-field>
|
</q-field>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
||||||
<div :class="` col-grow clpopupVisuCard ` + getclass()" :style="withBorder() ? `` : ``">
|
<div :class="` col-grow clpopupVisuCard ` + getclass()" :style="withBorder() ? `` : ``">
|
||||||
<CMyPopupEdit
|
<CMyPopupEdit
|
||||||
v-bind="$attrs"
|
v-bind="$attrs"
|
||||||
@@ -43,6 +44,7 @@
|
|||||||
:pickup="pickup"
|
:pickup="pickup"
|
||||||
v-model:row="rec"
|
v-model:row="rec"
|
||||||
minuteinterval="1"
|
minuteinterval="1"
|
||||||
|
:nosaveToDb="nosaveToDb"
|
||||||
@showandsave="showandsel"
|
@showandsave="showandsel"
|
||||||
>
|
>
|
||||||
|
|
||||||
|
|||||||
@@ -54,12 +54,12 @@ export default defineComponent({
|
|||||||
|
|
||||||
const load = async (): Promise<void> => {
|
const load = async (): Promise<void> => {
|
||||||
// console.log('load', mypath.value)
|
// console.log('load', mypath.value)
|
||||||
if (mypath.value !== '') rec.value = await globalStore.loadPage('/' + mypath.value)
|
if (mypath.value !== '') rec.value = await globalStore.loadPage('/' + mypath.value, 'cmypage')
|
||||||
}
|
}
|
||||||
|
|
||||||
watch(() => props.mypath, async (to: string, from: string) => {
|
watch(() => props.mypath, async (to: string, from: string) => {
|
||||||
// console.log('load', mypath.value)
|
console.log('load', mypath.value, to, from )
|
||||||
if (mypath.value !== '') rec.value = await globalStore.loadPage('/' + mypath.value)
|
if (mypath.value !== '') rec.value = await globalStore.loadPage('/' + mypath.value, 'cmypage watch')
|
||||||
})
|
})
|
||||||
|
|
||||||
onMounted(load)
|
onMounted(load)
|
||||||
|
|||||||
@@ -15,6 +15,7 @@ import { tools } from '@store/Modules/tools'
|
|||||||
import { useQuasar } from 'quasar'
|
import { useQuasar } from 'quasar'
|
||||||
import { useI18n } from '@/boot/i18n'
|
import { useI18n } from '@/boot/i18n'
|
||||||
import { shared_consts } from '@/common/shared_vuejs'
|
import { shared_consts } from '@/common/shared_vuejs'
|
||||||
|
import objectId from '@src/js/objectId'
|
||||||
|
|
||||||
export default defineComponent({
|
export default defineComponent({
|
||||||
name: 'CMyPageElem',
|
name: 'CMyPageElem',
|
||||||
@@ -59,13 +60,14 @@ export default defineComponent({
|
|||||||
const $q = useQuasar()
|
const $q = useQuasar()
|
||||||
|
|
||||||
const { t } = useI18n()
|
const { t } = useI18n()
|
||||||
|
const globalStore = useGlobalStore()
|
||||||
|
|
||||||
const editOn = ref(false)
|
const editOn = ref(false)
|
||||||
const addOn = ref(false)
|
const addOn = ref(false)
|
||||||
const selElem = ref({} as IMyElem)
|
const myelemVoid = ref({ _id: objectId(), active: true, type: shared_consts.ELEMTYPE.TEXT, container: '...', path: mypathin.value } as IMyElem)
|
||||||
const myelemVoid = ref({active: true, type: shared_consts.ELEMTYPE.TEXT, container: '...', path: mypathin.value} as IMyElem)
|
|
||||||
|
|
||||||
const globalStore = useGlobalStore()
|
|
||||||
|
const selElem = ref(globalStore.selElem)
|
||||||
|
|
||||||
const myelems = computed(() => {
|
const myelems = computed(() => {
|
||||||
if (mypathin.value)
|
if (mypathin.value)
|
||||||
@@ -74,37 +76,52 @@ export default defineComponent({
|
|||||||
return null
|
return null
|
||||||
})
|
})
|
||||||
|
|
||||||
|
function load() {
|
||||||
const load = async (): Promise<void> => {
|
|
||||||
// console.log('load', mypathin.value)
|
// console.log('load', mypathin.value)
|
||||||
if (mypathin.value !== '') rec.value = await globalStore.loadPage('/' + mypathin.value)
|
if (mypathin.value !== '') {
|
||||||
|
globalStore.loadPage('/' + mypathin.value, 'cmypageelem').then(ris => {
|
||||||
|
rec.value = ris
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
editOn.value = tools.getCookie('EDIT_' + mypathin.value) === '-1' ? true : false
|
if (tools.isManager()) {
|
||||||
if (mypathin.value === 'home')
|
editOn.value = tools.getCookie('EDITPAGES', '0') === '-1' ? true : false
|
||||||
editOn.value = false
|
console.log('getcookie: ', editOn.value, mypathin.value)
|
||||||
console.log('getcookie: ', editOn.value, mypathin.value)
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
watch(() => props.mypath, async (to: string, from: string) => {
|
watch(() => props.mypath, (to: string, from: string) => {
|
||||||
console.log('... load', mypathin.value, props.mypath)
|
console.log('... load', mypathin.value, props.mypath)
|
||||||
await load()
|
selElem.value = {}
|
||||||
|
load()
|
||||||
})
|
})
|
||||||
|
|
||||||
|
watch(
|
||||||
|
() => editOn.value,
|
||||||
|
() => {
|
||||||
|
if (!editOn.value) {
|
||||||
|
selElem.value = {}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
function selElemClick(myelem: IMyElem) {
|
function selElemClick(myelem: IMyElem) {
|
||||||
|
console.log('mypageelem selElemClick', myelem)
|
||||||
selElem.value = myelem
|
selElem.value = myelem
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function mounted() {
|
||||||
|
load()
|
||||||
|
}
|
||||||
|
|
||||||
function saveElem(myelem: IMyElem) {
|
function saveElem(myelem: IMyElem) {
|
||||||
//
|
//
|
||||||
}
|
}
|
||||||
|
|
||||||
function changeVisuDrawer() {
|
function changeVisuDrawer(path: string, edit: boolean) {
|
||||||
console.log('changeVisuDrawer')
|
globalStore.changeVisuDrawer(path, edit)
|
||||||
tools.setCookie('EDIT_' + mypathin.value, editOn.value ? '-1' : '0')
|
|
||||||
}
|
}
|
||||||
|
|
||||||
onMounted(load)
|
onMounted(mounted)
|
||||||
|
|
||||||
return {
|
return {
|
||||||
rec, myelems,
|
rec, myelems,
|
||||||
|
|||||||
@@ -5,35 +5,37 @@
|
|||||||
v-if="tools.isManager()"
|
v-if="tools.isManager()"
|
||||||
v-model="editOn"
|
v-model="editOn"
|
||||||
color="green"
|
color="green"
|
||||||
@update:model-value="changeVisuDrawer"
|
@update:model-value="changeVisuDrawer(mypathin, editOn)"
|
||||||
icon="fas fa-pencil-alt"
|
icon="fas fa-pencil-alt"
|
||||||
>
|
>
|
||||||
</q-toggle>
|
</q-toggle>
|
||||||
<q-drawer
|
<q-drawer
|
||||||
v-model="editOn"
|
v-model="editOn"
|
||||||
side="right"
|
side="right"
|
||||||
show-if-above
|
|
||||||
:width="400"
|
:width="400"
|
||||||
:breakpoint="700"
|
:breakpoint="700"
|
||||||
elevated
|
elevated
|
||||||
>
|
>
|
||||||
<q-bar dense class="bg-primary text-white">
|
<q-scroll-area class="fit">
|
||||||
<q-toolbar-title> Editor </q-toolbar-title>
|
<q-bar dense class="bg-primary text-white">
|
||||||
<q-btn
|
<q-toolbar-title> Editor </q-toolbar-title>
|
||||||
flat
|
<q-btn
|
||||||
round
|
flat
|
||||||
color="white"
|
round
|
||||||
icon="close"
|
color="white"
|
||||||
@click="editOn = false; changeVisuDrawer()"
|
icon="close"
|
||||||
></q-btn>
|
@click="
|
||||||
</q-bar>
|
editOn = false;
|
||||||
<CMyEditElem
|
"
|
||||||
:myelem="selElem"
|
></q-btn>
|
||||||
:editOn="true"
|
</q-bar>
|
||||||
:path="rec.path"
|
<CMyEditElem
|
||||||
@saveElem="saveElem"
|
:myelem="selElem"
|
||||||
>
|
:editOn="true"
|
||||||
</CMyEditElem>
|
:path="rec.path"
|
||||||
|
>
|
||||||
|
</CMyEditElem>
|
||||||
|
</q-scroll-area>
|
||||||
</q-drawer>
|
</q-drawer>
|
||||||
|
|
||||||
<div class="q-ma-sm q-gutter-sm q-pa-xs">
|
<div class="q-ma-sm q-gutter-sm q-pa-xs">
|
||||||
@@ -75,6 +77,7 @@
|
|||||||
:editOn="editOn"
|
:editOn="editOn"
|
||||||
:addOn="addOn"
|
:addOn="addOn"
|
||||||
:path="rec.path"
|
:path="rec.path"
|
||||||
|
:selElem="selElem"
|
||||||
@selElemClick="selElemClick"
|
@selElemClick="selElemClick"
|
||||||
>
|
>
|
||||||
</CMyElem>
|
</CMyElem>
|
||||||
@@ -85,7 +88,9 @@
|
|||||||
:myelem="myelemVoid"
|
:myelem="myelemVoid"
|
||||||
:editOn="editOn"
|
:editOn="editOn"
|
||||||
:addOn="addOn"
|
:addOn="addOn"
|
||||||
|
:selElem="selElem"
|
||||||
:path="rec.path"
|
:path="rec.path"
|
||||||
|
@selElemClick="selElemClick"
|
||||||
>
|
>
|
||||||
</CMyElem>
|
</CMyElem>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -13,6 +13,7 @@ import { CMySelect } from '../CMySelect'
|
|||||||
import { CCurrencyValue } from '../CCurrencyValue'
|
import { CCurrencyValue } from '../CCurrencyValue'
|
||||||
import { CMyEditor } from '../CMyEditor'
|
import { CMyEditor } from '../CMyEditor'
|
||||||
import { CGallery } from '../CGallery'
|
import { CGallery } from '../CGallery'
|
||||||
|
import { CSelectImage } from '../CSelectImage'
|
||||||
import { CAccomodation } from '../CAccomodation'
|
import { CAccomodation } from '../CAccomodation'
|
||||||
import { tools } from '@store/Modules/tools'
|
import { tools } from '@store/Modules/tools'
|
||||||
import { costanti } from '@costanti'
|
import { costanti } from '@costanti'
|
||||||
@@ -46,13 +47,18 @@ export default defineComponent({
|
|||||||
required: false,
|
required: false,
|
||||||
default: null,
|
default: null,
|
||||||
},
|
},
|
||||||
|
fielddb: {
|
||||||
|
type: Boolean,
|
||||||
|
required: false,
|
||||||
|
default: false,
|
||||||
|
},
|
||||||
isrec: {
|
isrec: {
|
||||||
type: Boolean,
|
type: Boolean,
|
||||||
required: false,
|
required: false,
|
||||||
default: false,
|
default: false,
|
||||||
},
|
},
|
||||||
mycol: {
|
mycol: {
|
||||||
type: Object as PropType<IColGridTable>,
|
type: Object as PropType<IColGridTable | undefined>,
|
||||||
required: true,
|
required: true,
|
||||||
},
|
},
|
||||||
canEdit: {
|
canEdit: {
|
||||||
@@ -185,9 +191,19 @@ export default defineComponent({
|
|||||||
required: false,
|
required: false,
|
||||||
default: false,
|
default: false,
|
||||||
},
|
},
|
||||||
|
nosaveToDb: {
|
||||||
|
type: Boolean,
|
||||||
|
required: false,
|
||||||
|
default: false,
|
||||||
|
},
|
||||||
|
path: {
|
||||||
|
type: String,
|
||||||
|
required: false,
|
||||||
|
default: '',
|
||||||
|
},
|
||||||
},
|
},
|
||||||
components: { CMyChipList, CDateTime, CDate, CMyToggleList, CMySelect, CMyEditor, CGallery,
|
components: { CMyChipList, CDateTime, CDate, CMyToggleList, CMySelect, CMyEditor, CGallery,
|
||||||
CCurrencyValue, CLabel, CAccomodation },
|
CCurrencyValue, CLabel, CAccomodation, CSelectImage },
|
||||||
setup(props, { emit }) {
|
setup(props, { emit }) {
|
||||||
const $q = useQuasar()
|
const $q = useQuasar()
|
||||||
const { t } = useI18n()
|
const { t } = useI18n()
|
||||||
@@ -203,14 +219,14 @@ export default defineComponent({
|
|||||||
|
|
||||||
const myImgGall = ref([{}] as IImgGallery[])
|
const myImgGall = ref([{}] as IImgGallery[])
|
||||||
|
|
||||||
const col = ref({
|
const col = ref(<IColGridTable>{
|
||||||
name: 'test',
|
name: 'test',
|
||||||
fieldtype: 0,
|
fieldtype: 0,
|
||||||
showWhen: costanti.showWhen.NewRec + costanti.showWhen.InEdit + costanti.showWhen.InView,
|
showWhen: costanti.showWhen.NewRec + costanti.showWhen.InEdit + costanti.showWhen.InView,
|
||||||
visible: true,
|
visible: true,
|
||||||
maxlength: props.mycol ? props.mycol.maxlength : 0,
|
maxlength: props.mycol ? props.mycol.maxlength : 0,
|
||||||
minlength: props.mycol ? props.mycol.minlength : undefined
|
minlength: props.mycol ? props.mycol.minlength : undefined
|
||||||
} as IColGridTable)
|
})
|
||||||
|
|
||||||
const { setValDb, getValDb } = MixinBase()
|
const { setValDb, getValDb } = MixinBase()
|
||||||
const { getMyUsername } = MixinUsers()
|
const { getMyUsername } = MixinUsers()
|
||||||
@@ -227,42 +243,42 @@ export default defineComponent({
|
|||||||
})
|
})
|
||||||
|
|
||||||
function crea() {
|
function crea() {
|
||||||
// console.log('crea', isFieldDb())
|
// console.log('crea', isFieldDb(), 'props.mycol', props.mycol)
|
||||||
|
|
||||||
|
if (props.mycol && props.mycol.name) {
|
||||||
|
col.value = props.mycol
|
||||||
|
} else {
|
||||||
|
col.value.jointable = props.jointable
|
||||||
|
if (props.filter)
|
||||||
|
col.value.filter = props.filter
|
||||||
|
col.value.fieldtype = props.type
|
||||||
|
col.value.label = props.title
|
||||||
|
|
||||||
|
if (props.type === costanti.FieldType.image) {
|
||||||
|
myImgGall.value = [{
|
||||||
|
_id: '',
|
||||||
|
imagefile: myvalue.value,
|
||||||
|
// order: 1,
|
||||||
|
alt: 'img',
|
||||||
|
}]
|
||||||
|
} else if (props.type === costanti.FieldType.imgcard) {
|
||||||
|
myImgGall.value = [myvalue.value]
|
||||||
|
}
|
||||||
|
|
||||||
|
console.log('* col', col.value);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (props.type) {
|
||||||
|
col.value.fieldtype = props.type
|
||||||
|
}
|
||||||
|
|
||||||
if (props.isrec) {
|
if (props.isrec) {
|
||||||
col.value = props.mycol
|
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
if (isFieldDb()) {
|
if (isFieldDb()) {
|
||||||
// mykey -> field
|
|
||||||
// mysubkey -> subfield
|
|
||||||
// table -> table
|
|
||||||
// serv -> serv
|
|
||||||
// id -> id
|
|
||||||
// idmain -> idmain
|
|
||||||
|
|
||||||
// console.table(props)
|
|
||||||
|
|
||||||
myvalue.value = getValDb(props.field, props.serv, '', props.table, props.subfield, props.id, props.idmain, props.indrec, props.mysubsubkey, props.specialField)
|
myvalue.value = getValDb(props.field, props.serv, '', props.table, props.subfield, props.id, props.idmain, props.indrec, props.mysubsubkey, props.specialField)
|
||||||
// console.log('myvalue.value', myvalue.value)
|
|
||||||
col.value.jointable = props.jointable
|
|
||||||
if (props.filter)
|
|
||||||
col.value.filter = props.filter
|
|
||||||
col.value.fieldtype = props.type
|
|
||||||
col.value.label = props.title
|
|
||||||
|
|
||||||
if (props.type === costanti.FieldType.image) {
|
|
||||||
myImgGall.value = [{
|
|
||||||
_id: '',
|
|
||||||
imagefile: myvalue.value,
|
|
||||||
// order: 1,
|
|
||||||
alt: 'img',
|
|
||||||
}]
|
|
||||||
}
|
|
||||||
|
|
||||||
// console.log('col', col.value);
|
|
||||||
} else {
|
} else {
|
||||||
col.value = { ...props.mycol }
|
if (props.mycol && props.mycol.name)
|
||||||
|
col.value = { ...props.mycol }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -275,7 +291,8 @@ export default defineComponent({
|
|||||||
|
|
||||||
|
|
||||||
function isFieldDb() {
|
function isFieldDb() {
|
||||||
return props.type !== 0
|
// return props.type !== 0
|
||||||
|
return props.fielddb
|
||||||
}
|
}
|
||||||
|
|
||||||
function isviewfield() {
|
function isviewfield() {
|
||||||
@@ -404,6 +421,8 @@ export default defineComponent({
|
|||||||
// console.log('myvalue.value', myvalue.value)
|
// console.log('myvalue.value', myvalue.value)
|
||||||
myvalueprec.value = myvalue.value
|
myvalueprec.value = myvalue.value
|
||||||
|
|
||||||
|
crea()
|
||||||
|
|
||||||
// console.log('myvalueprec', myvalueprec)
|
// console.log('myvalueprec', myvalueprec)
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -510,6 +529,9 @@ export default defineComponent({
|
|||||||
if (col.value.fieldtype === costanti.FieldType.image) {
|
if (col.value.fieldtype === costanti.FieldType.image) {
|
||||||
console.log('newVal.imagefile', newVal)
|
console.log('newVal.imagefile', newVal)
|
||||||
myvalue.value = newVal
|
myvalue.value = newVal
|
||||||
|
} else if (col.value.fieldtype === costanti.FieldType.imgcard) {
|
||||||
|
console.log('newVal.imagefile', newVal)
|
||||||
|
myvalue.value = newVal
|
||||||
}
|
}
|
||||||
|
|
||||||
if (col.value.fieldtype === costanti.FieldType.listobj) {
|
if (col.value.fieldtype === costanti.FieldType.listobj) {
|
||||||
@@ -660,52 +682,6 @@ export default defineComponent({
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function getTitleGall() {
|
|
||||||
if (fieldsTable.tableForUsers.includes(props.table)) {
|
|
||||||
return 'Profilo'
|
|
||||||
} else {
|
|
||||||
return fieldsTable.getTitleImgByTable(props.table)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function getDirectoryGall() {
|
|
||||||
console.log('getDirectoryGall', myrow.value)
|
|
||||||
|
|
||||||
let ris = ''
|
|
||||||
try {
|
|
||||||
let username = myrow.value.hasOwnProperty('username') ? myrow.value['username'] : ''
|
|
||||||
const userId = myrow.value.hasOwnProperty('userId') ? myrow.value['userId'] : ''
|
|
||||||
|
|
||||||
if (username === '') {
|
|
||||||
if (userId === userStore.my._id)
|
|
||||||
username = userStore.my.username
|
|
||||||
}
|
|
||||||
if (username === '') {
|
|
||||||
username = userStore.my.username
|
|
||||||
}
|
|
||||||
if (fieldsTable.tableForUsers.includes(props.table)) {
|
|
||||||
ris = 'profile/' + username + '/' + props.table
|
|
||||||
} else if (props.table === 'users') {
|
|
||||||
ris = 'profile/' + userStore.my.username
|
|
||||||
} else if (props.table === 'mygroups') {
|
|
||||||
if (myrow.value.hasOwnProperty('groupname'))
|
|
||||||
ris = 'mygroups/' + myrow.value['groupname']
|
|
||||||
} else if (props.table === 'circuits') {
|
|
||||||
if (myrow.value.hasOwnProperty('path'))
|
|
||||||
ris = 'circuits/' + myrow.value['path']
|
|
||||||
} else if (!!myrow.value && !!myrow.value.directory) {
|
|
||||||
ris = myrow.value.directory
|
|
||||||
} else if (props.table === 'myelems') {
|
|
||||||
ris = 'pages/' + myrow.value.path
|
|
||||||
} else {
|
|
||||||
ris = props.table
|
|
||||||
}
|
|
||||||
} catch (e) {
|
|
||||||
console.error('err getDirectoryGall', e)
|
|
||||||
}
|
|
||||||
console.log('getDirectoryGall', ris)
|
|
||||||
return ris
|
|
||||||
}
|
|
||||||
|
|
||||||
function uploaded(info: any) {
|
function uploaded(info: any) {
|
||||||
|
|
||||||
@@ -726,6 +702,7 @@ export default defineComponent({
|
|||||||
function noPopupeditByCol(mycol: IColGridTable) {
|
function noPopupeditByCol(mycol: IColGridTable) {
|
||||||
return (mycol.fieldtype !== costanti.FieldType.html
|
return (mycol.fieldtype !== costanti.FieldType.html
|
||||||
&& mycol.fieldtype !== costanti.FieldType.image
|
&& mycol.fieldtype !== costanti.FieldType.image
|
||||||
|
&& mycol.fieldtype !== costanti.FieldType.imgcard
|
||||||
&& mycol.fieldtype !== costanti.FieldType.listimages
|
&& mycol.fieldtype !== costanti.FieldType.listimages
|
||||||
&& mycol.fieldtype !== costanti.FieldType.listobj
|
&& mycol.fieldtype !== costanti.FieldType.listobj
|
||||||
&& mycol.fieldtype !== costanti.FieldType.number
|
&& mycol.fieldtype !== costanti.FieldType.number
|
||||||
@@ -749,7 +726,7 @@ export default defineComponent({
|
|||||||
|
|
||||||
onBeforeMount(mounted)
|
onBeforeMount(mounted)
|
||||||
|
|
||||||
crea()
|
|
||||||
|
|
||||||
return {
|
return {
|
||||||
myvalue,
|
myvalue,
|
||||||
@@ -778,8 +755,6 @@ export default defineComponent({
|
|||||||
onInput,
|
onInput,
|
||||||
globalStore,
|
globalStore,
|
||||||
userStore,
|
userStore,
|
||||||
getTitleGall,
|
|
||||||
getDirectoryGall,
|
|
||||||
removephoto,
|
removephoto,
|
||||||
isFieldDb,
|
isFieldDb,
|
||||||
col,
|
col,
|
||||||
|
|||||||
@@ -79,6 +79,7 @@
|
|||||||
<q-input
|
<q-input
|
||||||
v-bind="$attrs"
|
v-bind="$attrs"
|
||||||
v-model="myvalue"
|
v-model="myvalue"
|
||||||
|
|
||||||
:autogrow="col.fieldtype !== costanti.FieldType.crypted"
|
:autogrow="col.fieldtype !== costanti.FieldType.crypted"
|
||||||
:style="$q.screen.lt.sm ? 'min-width: 300px' : ''"
|
:style="$q.screen.lt.sm ? 'min-width: 300px' : ''"
|
||||||
counter
|
counter
|
||||||
@@ -173,8 +174,8 @@
|
|||||||
<div v-else-if="col.fieldtype === costanti.FieldType.listimages" style="text-align: center;">
|
<div v-else-if="col.fieldtype === costanti.FieldType.listimages" style="text-align: center;">
|
||||||
<CGallery
|
<CGallery
|
||||||
:imagebak="col.showpicprofile_ifnotset ? ((userStore.getImgByProfile(row, true) === '') ? costanti.NESSUN_IMMAGINE : userStore.getImgByProfile(row, true)) : ''"
|
:imagebak="col.showpicprofile_ifnotset ? ((userStore.getImgByProfile(row, true) === '') ? costanti.NESSUN_IMMAGINE : userStore.getImgByProfile(row, true)) : ''"
|
||||||
:title="getTitleGall()"
|
:title="tools.getTitleGall()"
|
||||||
:directory="getDirectoryGall()"
|
:directory="tools.getDirectoryGall(myrow, table, path)"
|
||||||
:imgGall="myvalue"
|
:imgGall="myvalue"
|
||||||
:isInModif="isInModif"
|
:isInModif="isInModif"
|
||||||
:edit="isviewfield() && isInModif"
|
:edit="isviewfield() && isInModif"
|
||||||
@@ -196,13 +197,13 @@
|
|||||||
{{ $t('reg.photo') }}
|
{{ $t('reg.photo') }}
|
||||||
<CGallery
|
<CGallery
|
||||||
:imagebak="col.showpicprofile_ifnotset ? userStore.getImgByProfile(row['profile'], true) : ''"
|
:imagebak="col.showpicprofile_ifnotset ? userStore.getImgByProfile(row['profile'], true) : ''"
|
||||||
:title="getTitleGall()"
|
:title="tools.getTitleGall()"
|
||||||
:directory="getDirectoryGall()"
|
:directory="tools.getDirectoryGall()"
|
||||||
:imgGall="[{ imagefile: myvalue }]"
|
:imgGall="[{ imagefile: myvalue }]"
|
||||||
:edit="isviewfield()"
|
:edit="isviewfield()"
|
||||||
:canModify="canModify"
|
:canModify="canModify"
|
||||||
:isInModif="isInModif"
|
:isInModif="isInModif"
|
||||||
:single="isFieldDb()"
|
:single="true"
|
||||||
@update:imgGall="changevalRec"
|
@update:imgGall="changevalRec"
|
||||||
@showandsave="Savedb">
|
@showandsave="Savedb">
|
||||||
</CGallery>
|
</CGallery>
|
||||||
@@ -232,6 +233,47 @@
|
|||||||
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
<div v-else-if="col.fieldtype === costanti.FieldType.imgcard">
|
||||||
|
<div v-if="canEdit">
|
||||||
|
{{ $t('reg.photo') }}
|
||||||
|
<CSelectImage
|
||||||
|
v-bind="$attrs"
|
||||||
|
:imagebak="col.showpicprofile_ifnotset ? userStore.getImgByProfile(row['profile'], true) : ''"
|
||||||
|
:title="tools.getTitleGall()"
|
||||||
|
:directory="tools.getDirectoryGall()"
|
||||||
|
:imgGall="[myvalue]"
|
||||||
|
:edit="isviewfield()"
|
||||||
|
:canModify="canModify"
|
||||||
|
:isInModif="isInModif"
|
||||||
|
@update:imgGall="changevalRec"
|
||||||
|
@showandsave="Savedb">
|
||||||
|
</CSelectImage>
|
||||||
|
</div>
|
||||||
|
<div v-else>
|
||||||
|
<div v-if="myvalue" class="text-center">
|
||||||
|
<q-img
|
||||||
|
:src="myvalue"
|
||||||
|
class="text-center"
|
||||||
|
style="height: 100px; width: 100px;"
|
||||||
|
alt="foto">
|
||||||
|
</q-img>
|
||||||
|
</div>
|
||||||
|
<div v-else class="text-center">
|
||||||
|
<q-img
|
||||||
|
:src="col.showpicprofile_ifnotset ? userStore.getImgByProfile(row['profile'], true) : 'images/noimg-user.svg'"
|
||||||
|
class="text-center"
|
||||||
|
style="height: 100px; width: 100px;"
|
||||||
|
alt="nessuna immagine">
|
||||||
|
</q-img>
|
||||||
|
</div>
|
||||||
|
<q-btn
|
||||||
|
v-if="myvalue"
|
||||||
|
label="Rimuovi Foto"
|
||||||
|
color="blue" icon="fas fa-trash-alt" size="sm"
|
||||||
|
@click="removephoto"></q-btn>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
<div v-else-if="col.fieldtype === costanti.FieldType.nationality">
|
<div v-else-if="col.fieldtype === costanti.FieldType.nationality">
|
||||||
<div v-if="isInModif" class="justify-center q-gutter-sm clgutter q-mt-sm">
|
<div v-if="isInModif" class="justify-center q-gutter-sm clgutter q-mt-sm">
|
||||||
<CMySelect
|
<CMySelect
|
||||||
@@ -604,6 +646,7 @@
|
|||||||
<div v-else>
|
<div v-else>
|
||||||
<span v-html="visuValByType(myvalue, col, row)"></span>
|
<span v-html="visuValByType(myvalue, col, row)"></span>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<q-popup-edit
|
<q-popup-edit
|
||||||
v-if="(!isInModif && canEdit && noPopupeditByCol(col))"
|
v-if="(!isInModif && canEdit && noPopupeditByCol(col))"
|
||||||
v-model="myvalue"
|
v-model="myvalue"
|
||||||
|
|||||||
@@ -11,7 +11,8 @@ export default defineComponent({
|
|||||||
props: {
|
props: {
|
||||||
modelValue: {
|
modelValue: {
|
||||||
type: String,
|
type: String,
|
||||||
required: true,
|
required: false,
|
||||||
|
default: '',
|
||||||
},
|
},
|
||||||
title: {
|
title: {
|
||||||
type: String,
|
type: String,
|
||||||
|
|||||||
@@ -11,7 +11,8 @@ export default defineComponent({
|
|||||||
props: {
|
props: {
|
||||||
modelValue: {
|
modelValue: {
|
||||||
type: String,
|
type: String,
|
||||||
required: true,
|
required: false,
|
||||||
|
default: '',
|
||||||
},
|
},
|
||||||
title: {
|
title: {
|
||||||
type: String,
|
type: String,
|
||||||
|
|||||||
65
src/components/CSelectImage/CSelectImage.scss
Executable file
@@ -0,0 +1,65 @@
|
|||||||
|
$heightBtn: 100%;
|
||||||
|
$grayshadow: #555;
|
||||||
|
|
||||||
|
.text-subtitle-gallery {
|
||||||
|
font-size: 1rem;
|
||||||
|
font-weight: 400;
|
||||||
|
line-height: 1.75rem;
|
||||||
|
letter-spacing: .00937em;
|
||||||
|
text-shadow: .1rem .1rem .1rem $grayshadow;
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 718px) {
|
||||||
|
// PER VERSIONE MOBILE
|
||||||
|
.text-subtitle-gallery {
|
||||||
|
font-size: 1rem;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.myimg {
|
||||||
|
border-radius: 10px !important;
|
||||||
|
height: 200px;
|
||||||
|
cursor: pointer;
|
||||||
|
}
|
||||||
|
|
||||||
|
.myimg-modify {
|
||||||
|
cursor: grab;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
.barwidth{
|
||||||
|
width: 250px !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
.q-img {
|
||||||
|
&__image {
|
||||||
|
border-radius: 10px !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.my-card-gallery {
|
||||||
|
width: 100%;
|
||||||
|
max-width: 300px;
|
||||||
|
min-width: 200px;
|
||||||
|
padding: 0.5rem 0.5rem;
|
||||||
|
height: 350px;
|
||||||
|
margin: auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
.my-card-gallery-noModif {
|
||||||
|
width: 100%;
|
||||||
|
max-width: 300px;
|
||||||
|
min-width: 200px;
|
||||||
|
padding: 1rem 1rem;
|
||||||
|
height: 220px;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
.my-card-gallery-view {
|
||||||
|
width: 100px;
|
||||||
|
height: 100px;
|
||||||
|
padding: 0.25rem 0.25rem;
|
||||||
|
margin: auto;
|
||||||
|
}
|
||||||
374
src/components/CSelectImage/CSelectImage.ts
Executable file
@@ -0,0 +1,374 @@
|
|||||||
|
import { defineComponent, ref, PropType, watch, onMounted, computed } from 'vue'
|
||||||
|
import { useI18n } from '@src/boot/i18n'
|
||||||
|
import { useUserStore } from '@store/UserStore'
|
||||||
|
import { useQuasar } from 'quasar'
|
||||||
|
import { IGallery, IImgGallery } from 'model'
|
||||||
|
import { CMyPage } from '@/components/CMyPage'
|
||||||
|
import { tools } from '@store/Modules/tools'
|
||||||
|
import { useGlobalStore } from '@store/globalStore'
|
||||||
|
import { costanti } from '@costanti'
|
||||||
|
|
||||||
|
export default defineComponent({
|
||||||
|
name: 'CSelectImage',
|
||||||
|
props: {
|
||||||
|
edit: {
|
||||||
|
type: Boolean,
|
||||||
|
required: true,
|
||||||
|
},
|
||||||
|
canModify: {
|
||||||
|
type: Boolean,
|
||||||
|
required: true,
|
||||||
|
},
|
||||||
|
isInModif: {
|
||||||
|
type: Boolean,
|
||||||
|
required: false,
|
||||||
|
default: false,
|
||||||
|
},
|
||||||
|
title: String,
|
||||||
|
directory: {
|
||||||
|
type: String,
|
||||||
|
required: true,
|
||||||
|
},
|
||||||
|
imagebak: {
|
||||||
|
type: String,
|
||||||
|
required: false,
|
||||||
|
default: '',
|
||||||
|
},
|
||||||
|
imgGall: {
|
||||||
|
type: Object as PropType<IImgGallery[] | string | undefined | null>,
|
||||||
|
required: true,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
emits: ['showandsave'],
|
||||||
|
components: { CMyPage },
|
||||||
|
setup(props, { emit }) {
|
||||||
|
const $q = useQuasar()
|
||||||
|
const { t } = useI18n()
|
||||||
|
const userStore = useUserStore()
|
||||||
|
const globalStore = useGlobalStore()
|
||||||
|
|
||||||
|
const displayGall = ref(false)
|
||||||
|
|
||||||
|
const gallerylist = ref(<IImgGallery[]>[])
|
||||||
|
const maximizedToggle = ref(true)
|
||||||
|
|
||||||
|
const fullscreen = ref(false)
|
||||||
|
const fullscreensrc = ref('')
|
||||||
|
|
||||||
|
|
||||||
|
function isValid(myobj: any): boolean {
|
||||||
|
return (myobj && typeof myobj !== 'string' && typeof myobj !== 'undefined')
|
||||||
|
}
|
||||||
|
|
||||||
|
const isListImgValid = computed(() => {
|
||||||
|
const arr = getlistimages()
|
||||||
|
if (arr && tools.isArray(arr)) {
|
||||||
|
return arr.length > 0
|
||||||
|
} else {
|
||||||
|
return !!arr
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
watch(() => props.imgGall, (newval, oldval) => {
|
||||||
|
updateArray()
|
||||||
|
})
|
||||||
|
|
||||||
|
function updateArray() {
|
||||||
|
// console.log('created cgallery')
|
||||||
|
// @ts-ignore
|
||||||
|
let myarr: any = props.imgGall
|
||||||
|
gallerylist.value = []
|
||||||
|
if (Array.isArray(myarr)) {
|
||||||
|
myarr.forEach((imgfile: string) => {
|
||||||
|
if (imgfile) {
|
||||||
|
gallerylist.value.push({ imagefile: imgfile })
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function created() {
|
||||||
|
updateArray()
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function showandsave(value: any) {
|
||||||
|
console.log('EMIT: showandsave')
|
||||||
|
emit('showandsave', value)
|
||||||
|
}
|
||||||
|
|
||||||
|
function getnumimages() {
|
||||||
|
if (gallerylist.value)
|
||||||
|
return gallerylist.value.length
|
||||||
|
else
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
function getlistimages() {
|
||||||
|
if (gallerylist.value)
|
||||||
|
// return gallerylist.value.slice().sort((a: any, b: any) => a.order! - b.order!)
|
||||||
|
return gallerylist.value
|
||||||
|
else
|
||||||
|
return null
|
||||||
|
}
|
||||||
|
|
||||||
|
function onDragStart(e: any) {
|
||||||
|
console.log('onDragStart')
|
||||||
|
e.dataTransfer.setData('text', e.target.id)
|
||||||
|
e.dataTransfer.dropEffect = 'move'
|
||||||
|
}
|
||||||
|
|
||||||
|
function onDragEnter(e: any) {
|
||||||
|
if (props.canModify) {
|
||||||
|
// don't drop on other draggables
|
||||||
|
if (e.target.draggable !== true) {
|
||||||
|
e.target.classList.add('drag-enter')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function onDragLeave(e: any) {
|
||||||
|
if (props.canModify) {
|
||||||
|
e.target.classList.remove('drag-enter')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function onDragOver(e: any) {
|
||||||
|
if (props.canModify) {
|
||||||
|
e.preventDefault()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function onDrop(e: any) {
|
||||||
|
if (props.canModify) {
|
||||||
|
console.log('onDrop', e)
|
||||||
|
e.preventDefault()
|
||||||
|
|
||||||
|
// don't drop on other draggables
|
||||||
|
if (e.target.draggable === true) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if (gallerylist.value) {
|
||||||
|
|
||||||
|
const draggedId = e.dataTransfer.getData('text')
|
||||||
|
let dragout = ''
|
||||||
|
try {
|
||||||
|
dragout = e.target.parentNode.parentNode.parentNode.id
|
||||||
|
} catch (err) {
|
||||||
|
dragout = ''
|
||||||
|
}
|
||||||
|
const draggedEl = document.getElementById(draggedId)
|
||||||
|
console.log('draggedId', draggedId, 'draggedEl', draggedEl)
|
||||||
|
console.log('dragout', dragout)
|
||||||
|
|
||||||
|
// check if original parent node
|
||||||
|
if (draggedEl) {
|
||||||
|
if (draggedEl.parentNode === e.target) {
|
||||||
|
e.target.classList.remove('drag-enter')
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const myindexIn = gallerylist.value.findIndex((rec: any) => rec._id === draggedId)
|
||||||
|
const myrecIn: IImgGallery = gallerylist.value[myindexIn]
|
||||||
|
|
||||||
|
let myrecOut: IImgGallery
|
||||||
|
const myindexout = gallerylist.value.findIndex((rec: any) => rec._id === dragout)
|
||||||
|
myrecOut = gallerylist.value[myindexout]
|
||||||
|
|
||||||
|
if (myindexIn === myindexout)
|
||||||
|
return
|
||||||
|
|
||||||
|
|
||||||
|
tools.array_move(gallerylist.value, myindexIn, myindexout)
|
||||||
|
|
||||||
|
// make the exchange
|
||||||
|
// draggedEl.parentNode.removeChild(draggedEl)
|
||||||
|
// e.target.appendChild(draggedEl)
|
||||||
|
e.target.classList.remove('drag-enter')
|
||||||
|
|
||||||
|
save()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function getclass() {
|
||||||
|
return (props.edit || displayGall.value) ? (props.isInModif ? 'my-card-gallery' : 'my-card-gallery-noModif') : 'my-card-gallery-view' + ' text-center'
|
||||||
|
}
|
||||||
|
|
||||||
|
function getclimg() {
|
||||||
|
let mycl = (props.edit || displayGall.value) ? 'myimg' : 'myimg-view'
|
||||||
|
if (props.canModify && props.edit)
|
||||||
|
mycl = mycl + ' myimg-modify'
|
||||||
|
return mycl
|
||||||
|
}
|
||||||
|
|
||||||
|
/*function getlastord() {
|
||||||
|
if (gallerylist.value) {
|
||||||
|
let myord = 0
|
||||||
|
for (const file of gallerylist.value) {
|
||||||
|
if (file.order! > myord)
|
||||||
|
myord = file.order!
|
||||||
|
}
|
||||||
|
|
||||||
|
return myord + 10
|
||||||
|
}
|
||||||
|
}*/
|
||||||
|
|
||||||
|
function uploaded(info: any) {
|
||||||
|
console.log('uploaded', info)
|
||||||
|
if (gallerylist.value) {
|
||||||
|
for (const file of info.files) {
|
||||||
|
gallerylist.value.push({ imagefile: file.name })
|
||||||
|
}
|
||||||
|
|
||||||
|
console.log('gallerylist', gallerylist.value)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function apri() {
|
||||||
|
displayGall.value = true
|
||||||
|
}
|
||||||
|
|
||||||
|
function deleted(rec: any) {
|
||||||
|
console.log('deleted', rec.imagefile)
|
||||||
|
// console.table(mylistimages)
|
||||||
|
|
||||||
|
if (gallerylist.value) {
|
||||||
|
const index = gallerylist.value.findIndex((elem: any) => elem.imagefile === rec.imagefile)
|
||||||
|
if (index > -1) {
|
||||||
|
gallerylist.value.splice(index, 1)
|
||||||
|
}
|
||||||
|
|
||||||
|
// mylistimages = mylistimages.pop((elem) => elem.imagefile !== rec.imagefile)
|
||||||
|
|
||||||
|
// console.table(mylistimages)
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function getfullname(rec: any) {
|
||||||
|
if (rec) {
|
||||||
|
return costanti.DIR_UPLOAD + props.directory + '/' + rec.imagefile
|
||||||
|
} else {
|
||||||
|
return props.imagebak
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
function copytoclipboard(rec: any) {
|
||||||
|
const filename = getfullname(rec)
|
||||||
|
tools.copyStringToClipboard($q, filename, true)
|
||||||
|
}
|
||||||
|
|
||||||
|
function deleteFile(rec: any) {
|
||||||
|
console.log('deleteFile....')
|
||||||
|
const filename = getfullname(rec)
|
||||||
|
const filenamerel = filename.replace(/^.*[\\\/]/, '')
|
||||||
|
|
||||||
|
$q.dialog({
|
||||||
|
message: 'Eliminare il file ' + filenamerel + '?',
|
||||||
|
html: true,
|
||||||
|
ok: {
|
||||||
|
label: 'Elimina',
|
||||||
|
push: true,
|
||||||
|
},
|
||||||
|
title: filenamerel,
|
||||||
|
cancel: true,
|
||||||
|
persistent: false,
|
||||||
|
}).onOk(async () => {
|
||||||
|
|
||||||
|
// Delete File on server:
|
||||||
|
const ris = await globalStore.DeleteFile({ filename })
|
||||||
|
// console.log('ris', ris)
|
||||||
|
if (ris)
|
||||||
|
deleted(rec)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
function save() {
|
||||||
|
console.log('CGallery save', gallerylist.value)
|
||||||
|
if (gallerylist.value.length > 0) {
|
||||||
|
emit('showandsave', gallerylist.value[0].imagefile)
|
||||||
|
} else {
|
||||||
|
emit('showandsave', '')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function close() {
|
||||||
|
return ''
|
||||||
|
}
|
||||||
|
|
||||||
|
function getsrcimg(imgfile: any) {
|
||||||
|
|
||||||
|
if (!imgfile.imagefile) {
|
||||||
|
return 'images/noimg.png';
|
||||||
|
}
|
||||||
|
if (imgfile) {
|
||||||
|
if (tools.getextfile(imgfile.imagefile) === 'pdf')
|
||||||
|
return 'images/images/pdf.jpg'
|
||||||
|
else
|
||||||
|
return costanti.DIR_UPLOAD + props.directory + '/' + imgfile.imagefile
|
||||||
|
} else {
|
||||||
|
return 'images/noimg.png';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function getParamDir() {
|
||||||
|
return tools.escapeslash(props.directory)
|
||||||
|
}
|
||||||
|
|
||||||
|
function getUrl() {
|
||||||
|
const myurl = tools.geturlupload() + getParamDir()
|
||||||
|
console.log('myurl', myurl)
|
||||||
|
return myurl
|
||||||
|
}
|
||||||
|
|
||||||
|
function ImgFullScreen(mygallery: IImgGallery) {
|
||||||
|
fullscreen.value = true
|
||||||
|
fullscreensrc.value = getfullname(mygallery)
|
||||||
|
}
|
||||||
|
|
||||||
|
function onRejected(rejectedEntries: any) {
|
||||||
|
// Notify plugin needs to be installed
|
||||||
|
// https://quasar.dev/quasar-plugins/notify#Installation
|
||||||
|
console.log('rejectedEntries', rejectedEntries)
|
||||||
|
$q.notify({
|
||||||
|
type: 'negative',
|
||||||
|
message: 'La Dimensione massima dell\'immagine è di 2 MB'
|
||||||
|
})
|
||||||
|
}
|
||||||
|
onMounted(created)
|
||||||
|
|
||||||
|
return {
|
||||||
|
getlistimages,
|
||||||
|
onDragStart,
|
||||||
|
onDragEnter,
|
||||||
|
onDragLeave,
|
||||||
|
onDragOver,
|
||||||
|
onDrop,
|
||||||
|
getclass,
|
||||||
|
getclimg,
|
||||||
|
copytoclipboard,
|
||||||
|
deleteFile,
|
||||||
|
getsrcimg,
|
||||||
|
tools,
|
||||||
|
uploaded,
|
||||||
|
gallerylist,
|
||||||
|
getnumimages,
|
||||||
|
apri,
|
||||||
|
displayGall,
|
||||||
|
save,
|
||||||
|
maximizedToggle,
|
||||||
|
getUrl,
|
||||||
|
close,
|
||||||
|
ImgFullScreen,
|
||||||
|
fullscreen,
|
||||||
|
fullscreensrc,
|
||||||
|
onRejected,
|
||||||
|
isListImgValid,
|
||||||
|
costanti,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
289
src/components/CSelectImage/CSelectImage.vue
Executable file
@@ -0,0 +1,289 @@
|
|||||||
|
<template>
|
||||||
|
<!--<div class="q-pa-md items-start " style="display: inline-flex; width: 800px;"> -->
|
||||||
|
|
||||||
|
<div v-if="!edit">
|
||||||
|
<div class="q-pa-xs">
|
||||||
|
<q-card v-if="isListImgValid" :class="getclass()" @click="apri">
|
||||||
|
<div v-for="(imgfile, index) in getlistimages()" :key="index">
|
||||||
|
<div v-if="index === 0">
|
||||||
|
<q-img
|
||||||
|
:src="getsrcimg(imgfile)" :class="getclimg()">
|
||||||
|
<div v-if="getnumimages() > 1" class="absolute-bottom text-shadow no-padding">
|
||||||
|
({{ getnumimages() }})
|
||||||
|
</div>
|
||||||
|
</q-img>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</q-card>
|
||||||
|
<div v-else-if="!isInModif && !isListImgValid && imagebak">
|
||||||
|
|
||||||
|
<q-card v-if="imagebak !== costanti.NESSUN_IMMAGINE" :class="getclass()" @click="ImgFullScreen(imgfile)">
|
||||||
|
<q-img
|
||||||
|
:src="imagebak" :class="getclimg()">
|
||||||
|
</q-img>
|
||||||
|
</q-card>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
<div v-else>
|
||||||
|
<q-card :class="getclass()" @click="apri">
|
||||||
|
<q-img
|
||||||
|
src="images/noimg.png" :class="getclimg()"
|
||||||
|
alt="no image">
|
||||||
|
</q-img>
|
||||||
|
</q-card>
|
||||||
|
</div>
|
||||||
|
<q-btn
|
||||||
|
v-if="isInModif"
|
||||||
|
color="primary" @click="apri"
|
||||||
|
icon="fas fa-file-upload"
|
||||||
|
:label="$t('gallery.load_image')">
|
||||||
|
</q-btn>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div v-else>
|
||||||
|
<div v-if="!isListImgValid">
|
||||||
|
<q-btn
|
||||||
|
flat round color="blue" icon="fas fa-tools" size="md"
|
||||||
|
@click="apri"></q-btn>
|
||||||
|
</div>
|
||||||
|
<div v-else>
|
||||||
|
<div class=" row">
|
||||||
|
<!--<q-draggable-rows
|
||||||
|
v-model="order">-->
|
||||||
|
|
||||||
|
<div v-for="(mygallery, index) in getlistimages()" :key="index">
|
||||||
|
<div
|
||||||
|
class="q-pa-sm q-gutter-sm"
|
||||||
|
@dragenter="onDragEnter"
|
||||||
|
@dragleave="onDragLeave"
|
||||||
|
|
||||||
|
@dragover="onDragOver">
|
||||||
|
<q-card
|
||||||
|
:id="mygallery._id" :class="getclass()"
|
||||||
|
:draggable="canModify"
|
||||||
|
@dragstart="onDragStart"
|
||||||
|
@drop="onDrop"
|
||||||
|
>
|
||||||
|
|
||||||
|
<q-img
|
||||||
|
:src="getsrcimg(mygallery)"
|
||||||
|
:class="getclimg()"
|
||||||
|
:alt="mygallery.alt">
|
||||||
|
<div class="absolute-bottom text-shadow">
|
||||||
|
<!-- <div class="text-h6 text-trans">{{ mygallery.description }} </div> -->
|
||||||
|
<div class="text-subtitle-carica text-trans">{{ mygallery.description }}</div>
|
||||||
|
</div>
|
||||||
|
</q-img>
|
||||||
|
|
||||||
|
<q-field
|
||||||
|
v-if="canModify"
|
||||||
|
stack-label
|
||||||
|
dense
|
||||||
|
label="Nome File">
|
||||||
|
<template v-slot:control>
|
||||||
|
<div class="self-center full-width no-outline" tabindex="0">{{ mygallery.imagefile }}</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
</q-field>
|
||||||
|
|
||||||
|
<q-input
|
||||||
|
v-if="canModify"
|
||||||
|
v-model="mygallery.description"
|
||||||
|
dense
|
||||||
|
:label="$t('proj.longdescr')"
|
||||||
|
@keyup.enter.stop
|
||||||
|
@update:model-value="save"
|
||||||
|
debounce="1000"
|
||||||
|
autofocus>
|
||||||
|
</q-input>
|
||||||
|
|
||||||
|
<q-card-actions align="center">
|
||||||
|
<q-btn
|
||||||
|
v-if="canModify"
|
||||||
|
flat round color="blue" icon="fas fa-copy" size="sm"
|
||||||
|
@click="copytoclipboard(mygallery)"></q-btn>
|
||||||
|
<q-btn
|
||||||
|
v-if="canModify"
|
||||||
|
flat round color="red" icon="fas fa-trash-alt" size="sm"
|
||||||
|
@click="deleteFile(mygallery)"></q-btn>
|
||||||
|
</q-card-actions>
|
||||||
|
</q-card>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="q-pa-sm">
|
||||||
|
<div v-if="edit" class="q-gutter-sm " style="max-height: 200px; width: 208px;">
|
||||||
|
<q-uploader
|
||||||
|
label="Aggiungi Immagine"
|
||||||
|
accept="image/jpeg, image/jpg, image/png, .pdf"
|
||||||
|
:url="getUrl()"
|
||||||
|
:headers="tools.getheaders()"
|
||||||
|
:max-file-size="3000000"
|
||||||
|
multiple
|
||||||
|
auto-upload
|
||||||
|
hide-upload-btn
|
||||||
|
no-thumbnails
|
||||||
|
@uploaded="uploaded"
|
||||||
|
@rejected="onRejected"
|
||||||
|
style="width: 208px"
|
||||||
|
></q-uploader>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<q-dialog
|
||||||
|
v-model="displayGall"
|
||||||
|
persistent
|
||||||
|
:maximized="maximizedToggle"
|
||||||
|
transition-show="slide-up"
|
||||||
|
transition-hide="slide-down"
|
||||||
|
>
|
||||||
|
<q-card>
|
||||||
|
<q-bar class="bg-primary text-white">
|
||||||
|
<q-space/>
|
||||||
|
|
||||||
|
<q-btn dense flat icon="minimize" @click="maximizedToggle = false" :disable="!maximizedToggle">
|
||||||
|
<q-tooltip v-if="maximizedToggle" class="bg-white text-primary">Minimize</q-tooltip>
|
||||||
|
</q-btn>
|
||||||
|
<q-btn dense flat icon="crop_square" @click="maximizedToggle = true" :disable="maximizedToggle">
|
||||||
|
<q-tooltip v-if="!maximizedToggle" class="bg-white text-primary">Maximize</q-tooltip>
|
||||||
|
</q-btn>
|
||||||
|
<q-btn dense flat icon="close" v-close-popup>
|
||||||
|
<q-tooltip class="bg-white text-primary">Close</q-tooltip>
|
||||||
|
</q-btn>
|
||||||
|
</q-bar>
|
||||||
|
|
||||||
|
<q-card-section>
|
||||||
|
<div class="text-h6">{{ title }}</div>
|
||||||
|
</q-card-section>
|
||||||
|
|
||||||
|
<q-card-section class="q-pt-none">
|
||||||
|
<div class=" row">
|
||||||
|
|
||||||
|
<div v-for="(mygallery, index) in getlistimages()" :key="index">
|
||||||
|
<div
|
||||||
|
class="q-pa-sm barwidth"
|
||||||
|
@dragenter="onDragEnter"
|
||||||
|
@dragleave="onDragLeave"
|
||||||
|
@dragover="onDragOver"
|
||||||
|
>
|
||||||
|
<q-bar
|
||||||
|
class="bg-primary text-white"
|
||||||
|
>
|
||||||
|
<q-btn flat round dense icon="menu" class="q-mr-sm"/>
|
||||||
|
<q-btn
|
||||||
|
v-if="canModify"
|
||||||
|
flat round icon="fas fa-copy" size="sm"
|
||||||
|
@click="copytoclipboard(mygallery)"></q-btn>
|
||||||
|
<div>
|
||||||
|
Foto {{ index + 1 }}
|
||||||
|
</div>
|
||||||
|
<q-space></q-space>
|
||||||
|
<q-btn v-if="canModify" flat round color="red" icon="fas fa-trash-alt"
|
||||||
|
@click="deleteFile(mygallery)"></q-btn>
|
||||||
|
</q-bar>
|
||||||
|
|
||||||
|
<q-card
|
||||||
|
:id="mygallery._id" :class="getclass()"
|
||||||
|
:data-ind="index"
|
||||||
|
:draggable="canModify"
|
||||||
|
@dragstart="onDragStart"
|
||||||
|
@drop="onDrop"
|
||||||
|
>
|
||||||
|
<q-img
|
||||||
|
:src="getsrcimg(mygallery)"
|
||||||
|
:class="getclimg()"
|
||||||
|
@click="ImgFullScreen(mygallery)"
|
||||||
|
:alt="mygallery.alt">
|
||||||
|
<div v-if="mygallery.description" class="absolute-bottom text-shadow">
|
||||||
|
<!-- <div class="text-h6 text-trans">{{ mygallery.description }} </div> -->
|
||||||
|
<div class="text-subtitle-carica text-trans">{{ mygallery.description }}</div>
|
||||||
|
</div>
|
||||||
|
</q-img>
|
||||||
|
<q-card-section>
|
||||||
|
<q-field
|
||||||
|
v-if="canModify"
|
||||||
|
stack-label
|
||||||
|
dense
|
||||||
|
label="Nome File">
|
||||||
|
<template v-slot:control>
|
||||||
|
<div class="self-center full-width no-outline" tabindex="0">{{ mygallery.imagefile }}</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
</q-field>
|
||||||
|
<q-input
|
||||||
|
v-if="canModify"
|
||||||
|
v-model="mygallery.description"
|
||||||
|
dense
|
||||||
|
:label="$t('proj.longdescr')"
|
||||||
|
@keyup.enter.stop
|
||||||
|
@update:model-value="save"
|
||||||
|
debounce="1000"
|
||||||
|
autofocus>
|
||||||
|
</q-input>
|
||||||
|
</q-card-section>
|
||||||
|
|
||||||
|
</q-card>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div
|
||||||
|
v-if="canModify"
|
||||||
|
class="q-pa-sm">
|
||||||
|
<div class="q-gutter-sm " style="max-height: 200px; width: 208px;">
|
||||||
|
<q-uploader
|
||||||
|
label="Aggiungi Immagine"
|
||||||
|
accept="image/jpeg, image/jpg, image/png, .pdf"
|
||||||
|
:url="getUrl()"
|
||||||
|
:headers="tools.getheaders()"
|
||||||
|
:max-file-size="40000000"
|
||||||
|
multiple
|
||||||
|
auto-upload
|
||||||
|
hide-upload-btn
|
||||||
|
no-thumbnails
|
||||||
|
@uploaded="uploaded"
|
||||||
|
@rejected="onRejected"
|
||||||
|
style="width: 208px"
|
||||||
|
></q-uploader>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div v-if="!isInModif && !isListImgValid && imagebak">
|
||||||
|
|
||||||
|
<q-card :class="getclass()" @click="ImgFullScreen(mygallery)">
|
||||||
|
<q-img
|
||||||
|
:src="imagebak" :class="getclimg()">
|
||||||
|
</q-img>
|
||||||
|
</q-card>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
<q-card-actions align="right">
|
||||||
|
|
||||||
|
<q-btn v-if="canModify" flat label="Annulla" color="primary" v-close-popup/>
|
||||||
|
<q-btn v-if="canModify" label="salva" color="primary" v-close-popup @click="save"/>
|
||||||
|
<q-btn v-if="!canModify" label="Chiudi" color="primary" v-close-popup/>
|
||||||
|
</q-card-actions>
|
||||||
|
|
||||||
|
</q-card-section>
|
||||||
|
</q-card>
|
||||||
|
</q-dialog>
|
||||||
|
<q-dialog
|
||||||
|
v-model="fullscreen"
|
||||||
|
:maximized="false"
|
||||||
|
transition-show="slide-up"
|
||||||
|
transition-hide="slide-down"
|
||||||
|
>
|
||||||
|
<q-card class="my-card">
|
||||||
|
<q-img v-if="fullscreensrc" alt="fullscreen" :src="fullscreensrc" @click="fullscreen = false"></q-img>
|
||||||
|
</q-card>
|
||||||
|
</q-dialog>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script lang="ts" src="./CSelectImage.ts">
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style lang="scss" scoped>
|
||||||
|
@import './CSelectImage.scss';
|
||||||
|
</style>
|
||||||
1
src/components/CSelectImage/index.ts
Executable file
@@ -0,0 +1 @@
|
|||||||
|
export {default as CSelectImage} from './CSelectImage.vue'
|
||||||
@@ -63,7 +63,7 @@
|
|||||||
field="username"
|
field="username"
|
||||||
:canEdit="false"
|
:canEdit="false"
|
||||||
:canModify="false"
|
:canModify="false"
|
||||||
:type="costanti.FieldType.username_chip">
|
:fieldtype="costanti.FieldType.username_chip">
|
||||||
</CMyFieldRec>
|
</CMyFieldRec>
|
||||||
|
|
||||||
</q-item-label>
|
</q-item-label>
|
||||||
|
|||||||
@@ -15,6 +15,7 @@ export * from './CMyAvatar'
|
|||||||
export * from './CMyCart'
|
export * from './CMyCart'
|
||||||
export * from './CMyFieldDb'
|
export * from './CMyFieldDb'
|
||||||
export * from './CMyFieldRec'
|
export * from './CMyFieldRec'
|
||||||
|
export * from './CSelectImage'
|
||||||
export * from './CMyPage'
|
export * from './CMyPage'
|
||||||
export * from './CMyPageElem'
|
export * from './CMyPageElem'
|
||||||
export * from './CMyPageIntro'
|
export * from './CMyPageIntro'
|
||||||
|
|||||||
@@ -295,7 +295,7 @@ $heightBtn: 100%;
|
|||||||
max-width: 400px;
|
max-width: 400px;
|
||||||
min-width: 250px;
|
min-width: 250px;
|
||||||
}
|
}
|
||||||
box-shadow: none;
|
// box-shadow: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
.my-card-withshadow {
|
.my-card-withshadow {
|
||||||
|
|||||||
@@ -10,8 +10,8 @@ const functionality: IFunctionality = {
|
|||||||
PWA: false,
|
PWA: false,
|
||||||
SHOW_USER_MENU: true, // Cambiare con true
|
SHOW_USER_MENU: true, // Cambiare con true
|
||||||
SHOW_PROFILE: true,
|
SHOW_PROFILE: true,
|
||||||
SHOW_REG_BUTTON: true,
|
SHOW_REG_BUTTON: false,
|
||||||
ENABLE_REGISTRATION: true,
|
ENABLE_REGISTRATION: false,
|
||||||
ENABLE_REG_BY_BOT: false,
|
ENABLE_REG_BY_BOT: false,
|
||||||
ENABLE_REG_NEED_TELEGRAM: false,
|
ENABLE_REG_NEED_TELEGRAM: false,
|
||||||
SHOW_NEWSLETTER: false,
|
SHOW_NEWSLETTER: false,
|
||||||
@@ -30,7 +30,7 @@ const functionality: IFunctionality = {
|
|||||||
SHOW_COMPETENZE: false,
|
SHOW_COMPETENZE: false,
|
||||||
ENABLE_VIEW_GROUPS: false,
|
ENABLE_VIEW_GROUPS: false,
|
||||||
ENABLE_VIEW_USERS: false,
|
ENABLE_VIEW_USERS: false,
|
||||||
ENABLE_VIEW_PROFILE: true,
|
ENABLE_VIEW_PROFILE: false,
|
||||||
}
|
}
|
||||||
|
|
||||||
// const SHOW_PROJINTHEMENU = false
|
// const SHOW_PROJINTHEMENU = false
|
||||||
@@ -490,7 +490,7 @@ const baseroutes: IListRoutes[] = [
|
|||||||
path: '/',
|
path: '/',
|
||||||
materialIcon: 'home',
|
materialIcon: 'home',
|
||||||
name: 'pages.home',
|
name: 'pages.home',
|
||||||
component: () => import('@src/root_spec/home_kolibrilab/home_kolibrilab.vue'),
|
component: () => import('@src/root/home/home.vue'),
|
||||||
reqauth: false,
|
reqauth: false,
|
||||||
inmenu: true,
|
inmenu: true,
|
||||||
infooter: true,
|
infooter: true,
|
||||||
|
|||||||
@@ -80,7 +80,7 @@ export let idbKeyval = (() => {
|
|||||||
let req;
|
let req;
|
||||||
await withStore('readonly', table, store => {
|
await withStore('readonly', table, store => {
|
||||||
req = store.getAll();
|
req = store.getAll();
|
||||||
console.log(' req', req)
|
// console.log(' req', req)
|
||||||
});
|
});
|
||||||
if (req) {
|
if (req) {
|
||||||
return req.result;
|
return req.result;
|
||||||
|
|||||||
@@ -6,23 +6,36 @@ import { tools } from '@store/Modules/tools'
|
|||||||
import { useQuasar } from 'quasar'
|
import { useQuasar } from 'quasar'
|
||||||
import { useMeta } from 'quasar'
|
import { useMeta } from 'quasar'
|
||||||
|
|
||||||
|
|
||||||
// You can declare a mixin as the same style as components.
|
// You can declare a mixin as the same style as components.
|
||||||
export default function () {
|
export default function () {
|
||||||
|
|
||||||
function setmeta(mym: IMetaTags) {
|
function setmeta(mym: IMetaTags) {
|
||||||
|
// cancellarlo...
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
|
||||||
|
function getMeta(mym: IMetaTags, t: any) {
|
||||||
|
|
||||||
//++Todo META TAGS!
|
//++Todo META TAGS!
|
||||||
/*
|
if (!mym || !mym.title)
|
||||||
useMeta(() => {
|
return
|
||||||
return {
|
|
||||||
title: mym.title,
|
return {
|
||||||
description: mym.description,
|
title: t('ws.sitename'),
|
||||||
keywords: mym.keywords,
|
titleTemplate: (title: any) => `${tools.getsuffisso()} ${mym.title} - ${t('ws.sitename')}`,
|
||||||
}
|
meta: {
|
||||||
})
|
keywords: {
|
||||||
|
name: 'keywords',
|
||||||
|
content: mym.keywords,
|
||||||
|
},
|
||||||
|
description: {
|
||||||
|
name: 'description',
|
||||||
|
content: mym.description,
|
||||||
|
},
|
||||||
|
equiv: { 'http-equiv': 'Content-Type', 'content': 'text/html; charset=UTF-8' },
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
*/
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function getsrcbyimg(myimg: string) {
|
function getsrcbyimg(myimg: string) {
|
||||||
@@ -35,5 +48,6 @@ export default function () {
|
|||||||
return {
|
return {
|
||||||
setmeta,
|
setmeta,
|
||||||
getsrcbyimg,
|
getsrcbyimg,
|
||||||
|
getMeta,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -141,6 +141,7 @@ export interface IMyElem {
|
|||||||
class?: string
|
class?: string
|
||||||
image?: string
|
image?: string
|
||||||
class2?: string
|
class2?: string
|
||||||
|
class3?: string
|
||||||
styleadd?: string
|
styleadd?: string
|
||||||
list?: IImgGallery[]
|
list?: IImgGallery[]
|
||||||
listcards?: IMyCard[]
|
listcards?: IMyCard[]
|
||||||
@@ -210,6 +211,8 @@ export interface ISites {
|
|||||||
telegram_support_chat?: string
|
telegram_support_chat?: string
|
||||||
pathreg_add?: string
|
pathreg_add?: string
|
||||||
confsite: IOption
|
confsite: IOption
|
||||||
|
description?: string
|
||||||
|
keywords?: string
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface INewsToSent {
|
export interface INewsToSent {
|
||||||
@@ -357,6 +360,8 @@ export interface IGlobalState {
|
|||||||
datastat?: INotData
|
datastat?: INotData
|
||||||
site?: ISites,
|
site?: ISites,
|
||||||
mygroups: IMyGroup[],
|
mygroups: IMyGroup[],
|
||||||
|
selElem?: IMyElem,
|
||||||
|
editOn?: boolean,
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface IMenuList {
|
export interface IMenuList {
|
||||||
@@ -492,9 +497,11 @@ export interface IImgGallery {
|
|||||||
}
|
}
|
||||||
|
|
||||||
export interface IMyCard {
|
export interface IMyCard {
|
||||||
|
_id?: string
|
||||||
imagefile?: string
|
imagefile?: string
|
||||||
alt?: string
|
alt?: string
|
||||||
description?: string
|
description?: string
|
||||||
|
style?: string
|
||||||
size?: string
|
size?: string
|
||||||
color?: string
|
color?: string
|
||||||
content?: string
|
content?: string
|
||||||
|
|||||||
@@ -1,21 +1,54 @@
|
|||||||
|
import { defineComponent, ref, onMounted, watch, computed } from 'vue'
|
||||||
|
|
||||||
import {
|
import { useGlobalStore } from '@store/globalStore'
|
||||||
defineComponent, ref, computed,
|
import { useRoute } from 'vue-router'
|
||||||
} from 'vue'
|
import { useUserStore } from '@store/UserStore'
|
||||||
|
|
||||||
import { tools } from '@src/store/Modules/tools'
|
import { tools } from '@src/store/Modules/tools'
|
||||||
import { CSkill } from '@/components/CSkill'
|
import { static_data } from '@src/db/static_data'
|
||||||
import { CChartMap } from '@src/components/CChartMap'
|
import { toolsext } from '@src/store/Modules/toolsext'
|
||||||
import { CMapsEsempio } from '@src/components/CMapsEsempio'
|
import { CMyPageElem } from '@components'
|
||||||
|
import MixinBase from '@src/mixins/mixin-base'
|
||||||
|
import MixinMetaTags from '@/mixins/mixin-metatags'
|
||||||
|
import { useMeta } from 'quasar'
|
||||||
|
import { useI18n } from '@src/boot/i18n'
|
||||||
|
|
||||||
|
|
||||||
export default defineComponent({
|
export default defineComponent({
|
||||||
name: 'Home',
|
name: 'Home',
|
||||||
components: { CSkill, CChartMap, CMapsEsempio },
|
components: { CMyPageElem },
|
||||||
setup() {
|
setup() {
|
||||||
|
|
||||||
|
const userStore = useUserStore()
|
||||||
|
const globalStore = useGlobalStore()
|
||||||
|
const { t } = useI18n()
|
||||||
|
|
||||||
|
const isfinishLoading = computed(() => globalStore.finishLoading)
|
||||||
|
|
||||||
|
const { getMeta } = MixinMetaTags()
|
||||||
|
|
||||||
|
const { setValDb, getValDb } = MixinBase()
|
||||||
|
|
||||||
|
function inizia() {
|
||||||
|
if (globalStore.site) {
|
||||||
|
useMeta(getMeta({
|
||||||
|
title: globalStore.site.name,
|
||||||
|
description: globalStore.site.description,
|
||||||
|
keywords: globalStore.site.keywords,
|
||||||
|
}, t))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
inizia()
|
||||||
|
|
||||||
return {
|
return {
|
||||||
tools,
|
tools,
|
||||||
|
toolsext,
|
||||||
|
static_data,
|
||||||
|
getValDb,
|
||||||
|
globalStore,
|
||||||
|
isfinishLoading,
|
||||||
}
|
}
|
||||||
|
|
||||||
},
|
},
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -1,23 +1,9 @@
|
|||||||
<template>
|
<template>
|
||||||
<q-page class="">
|
<div v-if="isfinishLoading">
|
||||||
<h1>Inizio:</h1>
|
<CMyPageElem title="Home" mypath="home">
|
||||||
|
|
||||||
<CSkill>
|
|
||||||
|
|
||||||
</CSkill>
|
|
||||||
|
|
||||||
<!--<CChartMap
|
|
||||||
title="Mappa"
|
|
||||||
subtitle="cartina..."
|
|
||||||
serie1="Serie 1"
|
|
||||||
>
|
|
||||||
|
|
||||||
</CChartMap>-->
|
|
||||||
|
|
||||||
<!--<CMapsEsempio></CMapsEsempio>-->
|
|
||||||
|
|
||||||
</q-page>
|
|
||||||
|
|
||||||
|
</CMyPageElem>
|
||||||
|
</div>
|
||||||
</template>
|
</template>
|
||||||
<script lang="ts" src="./home.ts">
|
<script lang="ts" src="./home.ts">
|
||||||
</script>
|
</script>
|
||||||
|
|||||||
@@ -19,14 +19,14 @@ export default defineComponent({
|
|||||||
const { setmeta } = MixinMetaTags()
|
const { setmeta } = MixinMetaTags()
|
||||||
|
|
||||||
async function created() {
|
async function created() {
|
||||||
rec.value = await globalStore.loadPage(route.path)
|
rec.value = await globalStore.loadPage(route.path, 'mypage.ts')
|
||||||
// console.log('MyPage created', rec.value)
|
// console.log('MyPage created', rec.value)
|
||||||
|
|
||||||
// console.log('mounted', this.rec)
|
// console.log('mounted', this.rec)
|
||||||
}
|
}
|
||||||
|
|
||||||
watch(path, async (to: string, from: string) => {
|
watch(path, async (to: string, from: string) => {
|
||||||
// console.log('watch path', path)
|
console.log('watch path', to, from)
|
||||||
rec.value = await globalStore.loadPage(to)
|
rec.value = await globalStore.loadPage(to)
|
||||||
// console.log('path change', rec.value)
|
// console.log('path change', rec.value)
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -1,452 +0,0 @@
|
|||||||
|
|
||||||
.testo-banda {
|
|
||||||
//background: -webkit-gradient(linear, left top, left bottom, from(#3144f0), to(transparent));
|
|
||||||
//background: linear-gradient(180deg, #3144f0, transparent);
|
|
||||||
//background: rgba(0, 0, 0, .6)
|
|
||||||
}
|
|
||||||
|
|
||||||
$grayshadow: #555;
|
|
||||||
|
|
||||||
$textcol: blue;
|
|
||||||
$textcol_scuro: darkblue;
|
|
||||||
|
|
||||||
p {
|
|
||||||
margin: 0 0 1.25rem;
|
|
||||||
//text-shadow: .125rem .125rem .25rem $grayshadow;
|
|
||||||
}
|
|
||||||
|
|
||||||
h4 {
|
|
||||||
font-size: 1.25rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.mycard {
|
|
||||||
visibility: hidden;
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing {
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing_background {
|
|
||||||
background: #000 url(../../../public/images/foto1.jpg) no-repeat 50% fixed;
|
|
||||||
background-size: cover
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing > section {
|
|
||||||
display: -webkit-box;
|
|
||||||
display: -ms-flexbox;
|
|
||||||
display: flex;
|
|
||||||
-webkit-box-pack: center;
|
|
||||||
-ms-flex-pack: center;
|
|
||||||
justify-content: center;
|
|
||||||
//padding: 0 16px
|
|
||||||
}
|
|
||||||
|
|
||||||
.intro {
|
|
||||||
display: flex;
|
|
||||||
justify-content: space-between;
|
|
||||||
align-items: stretch;
|
|
||||||
/* flex-flow: row nowrap; */
|
|
||||||
|
|
||||||
padding: 1.25rem 0 1.25rem 0;
|
|
||||||
margin: .125rem;
|
|
||||||
|
|
||||||
* {
|
|
||||||
width: 100%;
|
|
||||||
flex: 1;
|
|
||||||
margin-left: auto;
|
|
||||||
margin-right: auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
&__associazione {
|
|
||||||
min-width: 350px;
|
|
||||||
}
|
|
||||||
|
|
||||||
&__comeassociarsi {
|
|
||||||
min-width: 350px;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.subtitle {
|
|
||||||
font-weight: 600;
|
|
||||||
text-align: center;
|
|
||||||
letter-spacing: 0.125rem;
|
|
||||||
text-transform: uppercase;
|
|
||||||
font-size: 1rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing > section.padding {
|
|
||||||
padding: 5.62rem 1rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing > section.padding_testo {
|
|
||||||
padding-top: 1.25rem;
|
|
||||||
padding-bottom: 1rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing > section.padding_gallery {
|
|
||||||
padding-top: 3.125rem;
|
|
||||||
padding-bottom: 5.625rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing > section > div {
|
|
||||||
position: relative;
|
|
||||||
width: 100%
|
|
||||||
}
|
|
||||||
|
|
||||||
.maxwidth1200 {
|
|
||||||
max-width: 1200px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing__toolbar {
|
|
||||||
background: -webkit-gradient(linear, left top, left bottom, from(#000), to(transparent));
|
|
||||||
background: linear-gradient(180deg, #000, transparent);
|
|
||||||
padding: 0 !important
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing__toolbar .q-btn {
|
|
||||||
border-radius: 0 0 .315rem .315rem;
|
|
||||||
-ms-flex-item-align: stretch;
|
|
||||||
align-self: stretch
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing__hero {
|
|
||||||
min-height: 50vh
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing__header {
|
|
||||||
height: 18vh
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing__arrow {
|
|
||||||
bottom: 1.5rem;
|
|
||||||
opacity: .4
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing__front {
|
|
||||||
background: -webkit-gradient(linear, left top, left bottom, from(transparent), color-stop(15%, rgba(0, 0, 0, .6)));
|
|
||||||
background: linear-gradient(180deg, transparent, rgba(0, 0, 0, .6) 15%)
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing__logo {
|
|
||||||
width: 9.40rem;
|
|
||||||
height: 9.40rem;
|
|
||||||
margin-top: 1.315rem;
|
|
||||||
//-webkit-animation: logo-rotate 240s linear infinite;
|
|
||||||
//animation: logo-rotate 240s linear infinite
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing__features .q-icon {
|
|
||||||
font-size: 4rem
|
|
||||||
}
|
|
||||||
|
|
||||||
h4 {
|
|
||||||
line-height: 1.5;
|
|
||||||
text-shadow: .25rem .25rem .5rem $grayshadow;
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing__features h4, .landing__features h6 {
|
|
||||||
margin: 1rem 0
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing__features p {
|
|
||||||
opacity: .7;
|
|
||||||
font-size: 1rem;
|
|
||||||
line-height: 1.5;
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing__footer {
|
|
||||||
//background: -webkit-gradient(linear, left top, left bottom, color-stop(65%, rgba(0, 0, 0, .1)), to(#000));
|
|
||||||
background: linear-gradient(180deg, rgba(0, 0, 0, .8) 95%, #FFF);
|
|
||||||
padding-top: 4.5rem !important;
|
|
||||||
padding-bottom: 4.5rem !important;
|
|
||||||
padding-left: 1.25rem;
|
|
||||||
padding-right: 1.25rem;
|
|
||||||
color: #9f9f9f;
|
|
||||||
}
|
|
||||||
|
|
||||||
.icon_contact:hover {
|
|
||||||
color: blue;
|
|
||||||
border-color: white;
|
|
||||||
border-width: .0625rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing__footer .doc-link {
|
|
||||||
color: $textcol;
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing__footer .doc-link:hover {
|
|
||||||
opacity: .8
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing__swirl-bg {
|
|
||||||
background-repeat: no-repeat !important;
|
|
||||||
background-position: top;
|
|
||||||
background-size: contain !important;
|
|
||||||
background-image: url(../../../public/images/landing_first_section.png) !important
|
|
||||||
}
|
|
||||||
|
|
||||||
.feat-descr {
|
|
||||||
font-size: 1.15rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.feat-descr:hover {
|
|
||||||
transition: opacity 0.5s ease-in-out;
|
|
||||||
opacity: 0.9;
|
|
||||||
}
|
|
||||||
|
|
||||||
.q-col-gutter-sm {
|
|
||||||
padding: 3.125rem 3.125rem;
|
|
||||||
//margin-left: -48px
|
|
||||||
}
|
|
||||||
|
|
||||||
body.mobile .landing {
|
|
||||||
//background: unset
|
|
||||||
}
|
|
||||||
|
|
||||||
body.mobile .landing:before {
|
|
||||||
content: "";
|
|
||||||
position: fixed;
|
|
||||||
top: 0;
|
|
||||||
height: 100vh;
|
|
||||||
left: 0;
|
|
||||||
right: 0;
|
|
||||||
bottom: 0;
|
|
||||||
z-index: -1;
|
|
||||||
//background: #000 url(../../public/images/cover.jpg) 50%;
|
|
||||||
|
|
||||||
background-size: cover
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
@-webkit-keyframes logo-rotate {
|
|
||||||
to {
|
|
||||||
-webkit-transform: rotate(-1turn);
|
|
||||||
transform: rotate(-1turn)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@keyframes logo-rotate {
|
|
||||||
to {
|
|
||||||
-webkit-transform: rotate(-1turn);
|
|
||||||
transform: rotate(-1turn)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
.home {
|
|
||||||
//background-color: rgb(250, 250, 250);
|
|
||||||
padding: 3.125rem;
|
|
||||||
display: flex;
|
|
||||||
//flex-wrap: nowrap;
|
|
||||||
flex-direction: column;
|
|
||||||
align-items: center;
|
|
||||||
justify-content: space-between;
|
|
||||||
}
|
|
||||||
|
|
||||||
.btn-start {
|
|
||||||
margin: 3.125rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.shadow {
|
|
||||||
//color: white;
|
|
||||||
text-shadow: 0.125rem 0.125rem 0.25rem $grayshadow;
|
|
||||||
}
|
|
||||||
|
|
||||||
.text-h1, h1 {
|
|
||||||
font-size: 3rem;
|
|
||||||
font-weight: bold;
|
|
||||||
line-height: 3rem;
|
|
||||||
letter-spacing: -.01562em;
|
|
||||||
margin-bottom: 8px !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.text-h2 {
|
|
||||||
font-size: 3.75rem;
|
|
||||||
font-weight: 300;
|
|
||||||
line-height: 3.75rem;
|
|
||||||
letter-spacing: -.00833em;
|
|
||||||
}
|
|
||||||
|
|
||||||
.text-weight-bold {
|
|
||||||
font-weight: 700;
|
|
||||||
}
|
|
||||||
|
|
||||||
.text-vers {
|
|
||||||
font-size: 0.75rem;
|
|
||||||
font-weight: 400;
|
|
||||||
line-height: 1.75rem;
|
|
||||||
letter-spacing: .00937em;
|
|
||||||
text-shadow: .25rem .25rem .5rem $grayshadow;
|
|
||||||
}
|
|
||||||
|
|
||||||
.homep-cover-img-1 {
|
|
||||||
background: #000 url(../../../public/images/foto1.jpg) no-repeat 50% fixed;
|
|
||||||
//transition: background-image 1s ease-in-out;
|
|
||||||
}
|
|
||||||
|
|
||||||
.homep-cover-img-2 {
|
|
||||||
background: #000 url(../../../public/images/foto2.jpg) no-repeat 50% fixed;
|
|
||||||
//transition: background-image 1s ease-in-out;
|
|
||||||
}
|
|
||||||
|
|
||||||
.homep-cover-img-3 {
|
|
||||||
background: #000 url(../../../public/images/foto3.jpg) no-repeat 50% fixed;
|
|
||||||
//transition: background-image 1s ease-in-out;
|
|
||||||
}
|
|
||||||
|
|
||||||
.homep-cover-img.hide-filter:before {
|
|
||||||
opacity: 0
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing__footer-icons {
|
|
||||||
font-size: 1.75rem
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing__footer-icons a {
|
|
||||||
margin: 0 .5rem .5rem;
|
|
||||||
text-decoration: none;
|
|
||||||
outline: 0;
|
|
||||||
color: $textcol;
|
|
||||||
transition: color .28s
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing__footer-icons a:hover {
|
|
||||||
color: $textcol_scuro;
|
|
||||||
}
|
|
||||||
|
|
||||||
.doc-img {
|
|
||||||
max-width: 100%;
|
|
||||||
}
|
|
||||||
|
|
||||||
.mylist {
|
|
||||||
background: #3fdaff;
|
|
||||||
padding-left: 1.25rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.clgutter {
|
|
||||||
margin-top: 1.25rem;
|
|
||||||
padding: .62rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.carousel_img_3 {
|
|
||||||
//background-image: url(../../public/images/cibo_sano.jpg);
|
|
||||||
background-size: cover !important;
|
|
||||||
background-position: 50% center !important;
|
|
||||||
background-repeat: no-repeat !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
@media (max-width: 718px) {
|
|
||||||
// PER VERSIONE MOBILE
|
|
||||||
|
|
||||||
.landing__hero {
|
|
||||||
text-align: center
|
|
||||||
}
|
|
||||||
.landing__header {
|
|
||||||
height: 7vh
|
|
||||||
}
|
|
||||||
.clgutter {
|
|
||||||
margin-top: 0;
|
|
||||||
padding: 0;
|
|
||||||
}
|
|
||||||
.landing__hero .text-h1, h1 {
|
|
||||||
font-size: 2rem;
|
|
||||||
line-height: 2.05rem;
|
|
||||||
margin-bottom: 1.25rem
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing > section.padding {
|
|
||||||
padding: 2.5rem 1rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing > section.padding_testo {
|
|
||||||
padding-top: 1.25rem;
|
|
||||||
padding-bottom: 1rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing > section.padding_gallery {
|
|
||||||
padding-top: 3.125rem;
|
|
||||||
padding-bottom: 5.625rem;
|
|
||||||
|
|
||||||
max-width: 800px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing > section.padding_gallery > div {
|
|
||||||
padding-top: 3.125rem;
|
|
||||||
padding-bottom: 5.625rem;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing__features h4, .landing__features h6 {
|
|
||||||
margin: 1.25rem 0
|
|
||||||
}
|
|
||||||
|
|
||||||
h4 {
|
|
||||||
line-height: 1.4;
|
|
||||||
text-shadow: 0.25rem 0.25rem 0.5rem $grayshadow;
|
|
||||||
}
|
|
||||||
|
|
||||||
.landing .feature-item {
|
|
||||||
text-align: center;
|
|
||||||
margin-top: 1.25rem;
|
|
||||||
}
|
|
||||||
.landing__hero-content {
|
|
||||||
padding-bottom: 11.25rem;
|
|
||||||
}
|
|
||||||
.landing__hero2-content {
|
|
||||||
padding-bottom: 7.25rem;
|
|
||||||
}
|
|
||||||
.landing__hero-btns {
|
|
||||||
-webkit-box-pack: center;
|
|
||||||
-ms-flex-pack: center;
|
|
||||||
justify-content: center
|
|
||||||
}
|
|
||||||
|
|
||||||
.q-col-gutter-sm {
|
|
||||||
padding: .625rem .315rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.text-subtitle1 {
|
|
||||||
font-size: 1.25rem;
|
|
||||||
}
|
|
||||||
.text-vers {
|
|
||||||
font-size: 0.6rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.carousel_img_3 {
|
|
||||||
//background-image: url(../../public/images/cibo_sano.jpg);
|
|
||||||
background-size: 620px 620px !important;
|
|
||||||
background-position: 50% top !important;
|
|
||||||
background-repeat: no-repeat !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
.custom-caption {
|
|
||||||
text-align: center;
|
|
||||||
padding: .75rem;
|
|
||||||
color: $textcol;
|
|
||||||
background-color: rgba(0, 0, 0, .3);
|
|
||||||
}
|
|
||||||
|
|
||||||
.sfondo-grigio {
|
|
||||||
padding: 1rem;
|
|
||||||
color: $textcol;
|
|
||||||
background-color: rgba(0, 0, 0, .35);
|
|
||||||
}
|
|
||||||
|
|
||||||
.mycontacts {
|
|
||||||
color: gray;
|
|
||||||
letter-spacing: 0.078rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.mycontacts_title {
|
|
||||||
text-shadow: 0.125rem 0.125rem 0.125rem #555;
|
|
||||||
font-weight: bold;
|
|
||||||
color: #999;
|
|
||||||
letter-spacing: 0.125rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.mycontacts_text {
|
|
||||||
color: #999;
|
|
||||||
letter-spacing: 0.093rem;
|
|
||||||
}
|
|
||||||
@@ -1,57 +0,0 @@
|
|||||||
import { defineComponent, ref, onMounted, watch, computed } from 'vue'
|
|
||||||
|
|
||||||
import { useGlobalStore } from '@store/globalStore'
|
|
||||||
import { useRoute } from 'vue-router'
|
|
||||||
import { useUserStore } from '@store/UserStore'
|
|
||||||
|
|
||||||
import { Logo } from '@/components/logo'
|
|
||||||
|
|
||||||
import { LandingFooter } from '@/components/LandingFooter'
|
|
||||||
import { CMyPageElem } from '@/components/CMyPageElem/index'
|
|
||||||
|
|
||||||
import { tools } from '@src/store/Modules/tools'
|
|
||||||
import { static_data } from '@src/db/static_data'
|
|
||||||
import { toolsext } from '@src/store/Modules/toolsext'
|
|
||||||
import { Screen } from 'quasar'
|
|
||||||
import { CCardCarousel, CEventsCalendar, CMyElem, COpenStreetMap } from '@components'
|
|
||||||
import MixinBase from '@src/mixins/mixin-base'
|
|
||||||
import { firstimagehome } from '@src/db/static_data'
|
|
||||||
import MixinMetaTags from '@/mixins/mixin-metatags'
|
|
||||||
|
|
||||||
export default defineComponent({
|
|
||||||
name: 'home_kolibrilab',
|
|
||||||
components: { Logo, LandingFooter, CMyPageElem, CMyElem },
|
|
||||||
|
|
||||||
setup() {
|
|
||||||
const userStore = useUserStore()
|
|
||||||
const globalStore = useGlobalStore()
|
|
||||||
|
|
||||||
const { setmeta } = MixinMetaTags()
|
|
||||||
|
|
||||||
const { setValDb, getValDb } = MixinBase()
|
|
||||||
|
|
||||||
function getheightgallery() {
|
|
||||||
if (tools.isMobile())
|
|
||||||
return '400px'
|
|
||||||
else
|
|
||||||
return '600px'
|
|
||||||
}
|
|
||||||
|
|
||||||
function created() {
|
|
||||||
//
|
|
||||||
}
|
|
||||||
|
|
||||||
created()
|
|
||||||
|
|
||||||
return {
|
|
||||||
tools,
|
|
||||||
toolsext,
|
|
||||||
static_data,
|
|
||||||
getheightgallery,
|
|
||||||
getValDb,
|
|
||||||
globalStore,
|
|
||||||
setmeta,
|
|
||||||
}
|
|
||||||
},
|
|
||||||
})
|
|
||||||
|
|
||||||
@@ -1,24 +0,0 @@
|
|||||||
<template>
|
|
||||||
<CMyPageElem
|
|
||||||
title="Home"
|
|
||||||
mypath="home"
|
|
||||||
>
|
|
||||||
|
|
||||||
<span>{{
|
|
||||||
setmeta({
|
|
||||||
title: '',
|
|
||||||
description: '',
|
|
||||||
keywords: '',
|
|
||||||
})
|
|
||||||
}}
|
|
||||||
</span>
|
|
||||||
|
|
||||||
</CMyPageElem>
|
|
||||||
</template>
|
|
||||||
|
|
||||||
<script lang="ts" src="./home_kolibrilab.ts">
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<style lang="scss" scoped>
|
|
||||||
@import './home_kolibrilab.scss';
|
|
||||||
</style>
|
|
||||||
@@ -1,17 +1,89 @@
|
|||||||
<template>
|
<template>
|
||||||
<CMyPage title="Configura Sito" imgbackground="images/calendario_eventi.jpg" sizes="max-height: 120px">
|
<CMyPage
|
||||||
|
title="Configura Sito"
|
||||||
|
imgbackground="images/calendario_eventi.jpg"
|
||||||
|
sizes="max-height: 120px"
|
||||||
|
>
|
||||||
<div class="q-ma-sm q-gutter-sm q-pa-xs">
|
<div class="q-ma-sm q-gutter-sm q-pa-xs">
|
||||||
|
|
||||||
<div v-if="mysite">
|
<div v-if="mysite">
|
||||||
<q-banner
|
<q-banner
|
||||||
rounded
|
rounded
|
||||||
class="bg-primary text-white"
|
class="bg-primary text-white"
|
||||||
color="primary q-title"
|
color="primary q-title"
|
||||||
style="text-align: center;">
|
style="text-align: center"
|
||||||
<p class="mybanner">{{mysite.name}}</p>
|
>
|
||||||
|
<p class="mybanner">{{ mysite.name }}</p>
|
||||||
</q-banner>
|
</q-banner>
|
||||||
|
|
||||||
|
<CMyFieldDb
|
||||||
|
title="Attivo"
|
||||||
|
table="sites"
|
||||||
|
mykey="active"
|
||||||
|
:id="mysite._id"
|
||||||
|
:rec="mysite"
|
||||||
|
>
|
||||||
|
</CMyFieldDb>
|
||||||
|
|
||||||
|
<CMyFieldDb
|
||||||
|
title="Email Admin"
|
||||||
|
table="sites"
|
||||||
|
:id="mysite._id"
|
||||||
|
:rec="mysite"
|
||||||
|
mykey="adminemail"
|
||||||
|
debounce="1000"
|
||||||
|
>
|
||||||
|
</CMyFieldDb>
|
||||||
|
|
||||||
|
|
||||||
|
<CMyFieldDb
|
||||||
|
title="Titolo"
|
||||||
|
table="sites"
|
||||||
|
:id="mysite._id"
|
||||||
|
:rec="mysite"
|
||||||
|
mykey="name"
|
||||||
|
debounce="1000"
|
||||||
|
>
|
||||||
|
</CMyFieldDb>
|
||||||
|
|
||||||
|
<CMyFieldDb
|
||||||
|
title="Descrizione"
|
||||||
|
debounce="1000"
|
||||||
|
table="sites"
|
||||||
|
:id="mysite._id"
|
||||||
|
:rec="mysite"
|
||||||
|
mykey="description"
|
||||||
|
>
|
||||||
|
</CMyFieldDb>
|
||||||
|
|
||||||
|
<CMyFieldDb
|
||||||
|
title="Parole Chiave"
|
||||||
|
table="sites"
|
||||||
|
:id="mysite._id"
|
||||||
|
:rec="mysite"
|
||||||
|
mykey="keywords"
|
||||||
|
debounce="1000"
|
||||||
|
>
|
||||||
|
</CMyFieldDb>
|
||||||
|
|
||||||
|
<CMyFieldDb
|
||||||
|
title="Host"
|
||||||
|
table="sites"
|
||||||
|
:id="mysite._id"
|
||||||
|
:rec="mysite"
|
||||||
|
mykey="host"
|
||||||
|
debounce="1000"
|
||||||
|
>
|
||||||
|
</CMyFieldDb>
|
||||||
|
|
||||||
|
<CMyFieldDb
|
||||||
|
title="Host Test"
|
||||||
|
table="sites"
|
||||||
|
:id="mysite._id"
|
||||||
|
:rec="mysite"
|
||||||
|
mykey="host_test"
|
||||||
|
debounce="1000"
|
||||||
|
>
|
||||||
|
</CMyFieldDb>
|
||||||
|
|
||||||
<CMyFieldRec
|
<CMyFieldRec
|
||||||
title="Opzioni Sito"
|
title="Opzioni Sito"
|
||||||
@@ -28,35 +100,45 @@
|
|||||||
:serv="false"
|
:serv="false"
|
||||||
:type="costanti.FieldType.string">
|
:type="costanti.FieldType.string">
|
||||||
</CMyFieldDb>
|
</CMyFieldDb>
|
||||||
<CMyFieldDb title="Nome del BOT Telegram"
|
|
||||||
mykey="TELEG_BOT_NAME"
|
<CMyFieldDb
|
||||||
:serv="false"
|
title="Nome del BOT Telegram"
|
||||||
:type="costanti.FieldType.string">
|
mykey="TELEG_BOT_NAME"
|
||||||
|
:serv="false"
|
||||||
|
:type="costanti.FieldType.string"
|
||||||
|
debounce="1000"
|
||||||
|
>
|
||||||
</CMyFieldDb>
|
</CMyFieldDb>
|
||||||
<CMyFieldDb title="BOT Telegram (per Test)"
|
<CMyFieldDb
|
||||||
mykey="TELEG_BOT_LINK_TEST"
|
title="BOT Telegram (per Test)"
|
||||||
:serv="false"
|
mykey="TELEG_BOT_LINK_TEST"
|
||||||
:type="costanti.FieldType.string">
|
:serv="false"
|
||||||
|
debounce="1000"
|
||||||
|
:type="costanti.FieldType.string"
|
||||||
|
>
|
||||||
</CMyFieldDb>
|
</CMyFieldDb>
|
||||||
<CMyFieldDb title="Chat di Supporto (Help)"
|
<CMyFieldDb
|
||||||
mykey="TELEGRAM_SUPPORT"
|
title="Chat di Supporto (Help)"
|
||||||
:serv="false"
|
mykey="TELEGRAM_SUPPORT"
|
||||||
:type="costanti.FieldType.string">
|
:serv="false"
|
||||||
|
:type="costanti.FieldType.string"
|
||||||
|
debounce="1000"
|
||||||
|
>
|
||||||
</CMyFieldDb>
|
</CMyFieldDb>
|
||||||
<CMyFieldDb title="Sito ONLINE"
|
<CMyFieldDb
|
||||||
mykey="SITO_ONLINE"
|
title="Sito ONLINE"
|
||||||
:serv="false"
|
mykey="SITO_ONLINE"
|
||||||
:type="costanti.FieldType.boolean">
|
:serv="false"
|
||||||
|
:type="costanti.FieldType.boolean"
|
||||||
|
debounce="1000"
|
||||||
|
>
|
||||||
</CMyFieldDb>
|
</CMyFieldDb>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
</CMyPage>
|
</CMyPage>
|
||||||
</template>
|
</template>
|
||||||
<script lang="ts" src="./confsite.ts">
|
<script lang="ts" src="./confsite.ts">
|
||||||
|
|
||||||
</script>
|
</script>
|
||||||
<style lang="scss" scoped>
|
<style lang="scss" scoped>
|
||||||
@import 'confsite.scss';
|
@import 'confsite.scss';
|
||||||
|
|||||||
@@ -127,7 +127,7 @@ export const Api = {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (tools.isDebug())
|
if (tools.isDebug())
|
||||||
console.log('result', res)
|
console.log(' ----> ', res)
|
||||||
return resolve(res)
|
return resolve(res)
|
||||||
})
|
})
|
||||||
.catch((error) => {
|
.catch((error) => {
|
||||||
|
|||||||
@@ -272,6 +272,7 @@ export const costanti = {
|
|||||||
listimages: 1024,
|
listimages: 1024,
|
||||||
exact: 2048,
|
exact: 2048,
|
||||||
image: 3000,
|
image: 3000,
|
||||||
|
imgcard: 3500,
|
||||||
select_by_server: 4000,
|
select_by_server: 4000,
|
||||||
multiselect_by_server: 4010,
|
multiselect_by_server: 4010,
|
||||||
nationality: 4096,
|
nationality: 4096,
|
||||||
|
|||||||
@@ -123,6 +123,18 @@ export const colgallery = [
|
|||||||
AddCol(DuplicateRec),
|
AddCol(DuplicateRec),
|
||||||
]
|
]
|
||||||
|
|
||||||
|
export const colmylistcards = [
|
||||||
|
AddCol({ name: 'imagefile', label_trans: 'imagefile', fieldtype: costanti.FieldType.string }),
|
||||||
|
AddCol({ name: 'alt', label_trans: 'alt', fieldtype: costanti.FieldType.string }),
|
||||||
|
AddCol({ name: 'description', label_trans: 'description', fieldtype: costanti.FieldType.string }),
|
||||||
|
AddCol({ name: 'style', label_trans: 'style' }),
|
||||||
|
AddCol({ name: 'alt', label_trans: 'alt' }),
|
||||||
|
AddCol({ name: 'size', label_trans: 'size' }),
|
||||||
|
AddCol({ name: 'color', label_trans: 'color' }),
|
||||||
|
AddCol({ name: 'content', label_trans: 'content' }),
|
||||||
|
AddCol({ name: 'colorsub', label_trans: 'colorsub' }),
|
||||||
|
]
|
||||||
|
|
||||||
export const colmyelems = [
|
export const colmyelems = [
|
||||||
AddCol({ name: 'active', label_trans: 'myelems.active', fieldtype: costanti.FieldType.boolean }),
|
AddCol({ name: 'active', label_trans: 'myelems.active', fieldtype: costanti.FieldType.boolean }),
|
||||||
AddCol({ name: 'path', label_trans: 'myelems.path' }),
|
AddCol({ name: 'path', label_trans: 'myelems.path' }),
|
||||||
@@ -188,9 +200,14 @@ export const colmsg_templates = [
|
|||||||
]
|
]
|
||||||
|
|
||||||
export const colmypage = [
|
export const colmypage = [
|
||||||
|
AddCol({ name: 'path', label_trans: 'pages.path' }),
|
||||||
|
AddCol({ name: 'icon', label_trans: 'pages.icon' }),
|
||||||
|
AddCol({ name: 'order', label_trans: 'pages.order', fieldtype: costanti.FieldType.number }),
|
||||||
|
AddCol({ name: 'active', label_trans: 'pages.active', fieldtype: costanti.FieldType.boolean }),
|
||||||
|
AddCol({ name: 'inmenu', label_trans: 'pages.inmenu', fieldtype: costanti.FieldType.boolean }),
|
||||||
|
AddCol({ name: 'infooter', label_trans: 'pages.infooter', fieldtype: costanti.FieldType.boolean }),
|
||||||
AddCol({ name: 'title', label_trans: 'pages.title' }),
|
AddCol({ name: 'title', label_trans: 'pages.title' }),
|
||||||
AddCol({ name: 'subtitle', label_trans: 'pages.subtitle' }),
|
AddCol({ name: 'subtitle', label_trans: 'pages.subtitle' }),
|
||||||
AddCol({ name: 'path', label_trans: 'pages.path' }),
|
|
||||||
AddCol({ name: 'img1', label_trans: 'pages.img1' }),
|
AddCol({ name: 'img1', label_trans: 'pages.img1' }),
|
||||||
AddCol({ name: 'content', label_trans: 'pages.contentfield', fieldtype: costanti.FieldType.html }),
|
AddCol({ name: 'content', label_trans: 'pages.contentfield', fieldtype: costanti.FieldType.html }),
|
||||||
AddCol({ name: 'video1', label_trans: 'pages.video1' }),
|
AddCol({ name: 'video1', label_trans: 'pages.video1' }),
|
||||||
@@ -205,8 +222,6 @@ export const colmypage = [
|
|||||||
AddCol({ name: 'ratio3', label_trans: 'pages.ratio3' }),
|
AddCol({ name: 'ratio3', label_trans: 'pages.ratio3' }),
|
||||||
AddCol({ name: 'content4', label_trans: 'pages.content4', fieldtype: costanti.FieldType.html }),
|
AddCol({ name: 'content4', label_trans: 'pages.content4', fieldtype: costanti.FieldType.html }),
|
||||||
AddCol({ name: 'lang', label_trans: 'pages.lang' }),
|
AddCol({ name: 'lang', label_trans: 'pages.lang' }),
|
||||||
AddCol({ name: 'icon', label_trans: 'pages.icon' }),
|
|
||||||
AddCol({ name: 'order', label_trans: 'pages.order', fieldtype: costanti.FieldType.number }),
|
|
||||||
AddCol({ name: 'keywords', label_trans: 'pages.keywords' }),
|
AddCol({ name: 'keywords', label_trans: 'pages.keywords' }),
|
||||||
AddCol({ name: 'description', label_trans: 'pages.description' }),
|
AddCol({ name: 'description', label_trans: 'pages.description' }),
|
||||||
AddCol({ name: 'heightimg', label_trans: 'pages.heightimg', fieldtype: costanti.FieldType.number }),
|
AddCol({ name: 'heightimg', label_trans: 'pages.heightimg', fieldtype: costanti.FieldType.number }),
|
||||||
@@ -215,12 +230,9 @@ export const colmypage = [
|
|||||||
AddCol({ name: 'only_residenti', label_trans: 'pages.only_residenti', fieldtype: costanti.FieldType.boolean }),
|
AddCol({ name: 'only_residenti', label_trans: 'pages.only_residenti', fieldtype: costanti.FieldType.boolean }),
|
||||||
AddCol({ name: 'only_consiglio', label_trans: 'pages.only_consiglio', fieldtype: costanti.FieldType.boolean }),
|
AddCol({ name: 'only_consiglio', label_trans: 'pages.only_consiglio', fieldtype: costanti.FieldType.boolean }),
|
||||||
AddCol({ name: 'imgback', label_trans: 'pages.imgback', fieldtype: costanti.FieldType.string }),
|
AddCol({ name: 'imgback', label_trans: 'pages.imgback', fieldtype: costanti.FieldType.string }),
|
||||||
AddCol({ name: 'active', label_trans: 'pages.active', fieldtype: costanti.FieldType.boolean }),
|
|
||||||
AddCol({ name: 'inmenu', label_trans: 'pages.inmenu', fieldtype: costanti.FieldType.boolean }),
|
|
||||||
AddCol({ name: 'submenu', label_trans: 'pages.submenu', fieldtype: costanti.FieldType.boolean }),
|
AddCol({ name: 'submenu', label_trans: 'pages.submenu', fieldtype: costanti.FieldType.boolean }),
|
||||||
AddCol({ name: 'l_par', label_trans: 'pages.l_par', fieldtype: costanti.FieldType.number }),
|
AddCol({ name: 'l_par', label_trans: 'pages.l_par', fieldtype: costanti.FieldType.number }),
|
||||||
AddCol({ name: 'l_child', label_trans: 'pages.l_child', fieldtype: costanti.FieldType.number }),
|
AddCol({ name: 'l_child', label_trans: 'pages.l_child', fieldtype: costanti.FieldType.number }),
|
||||||
AddCol({ name: 'infooter', label_trans: 'pages.infooter', fieldtype: costanti.FieldType.boolean }),
|
|
||||||
AddCol({ name: 'internalpage', label_trans: 'pages.internalpage', fieldtype: costanti.FieldType.boolean }),
|
AddCol({ name: 'internalpage', label_trans: 'pages.internalpage', fieldtype: costanti.FieldType.boolean }),
|
||||||
AddCol({ name: 'iconsize', label_trans: 'pages.iconsize', fieldtype: costanti.FieldType.string }),
|
AddCol({ name: 'iconsize', label_trans: 'pages.iconsize', fieldtype: costanti.FieldType.string }),
|
||||||
AddCol({ name: 'extraclass', label_trans: 'pages.extraclass', fieldtype: costanti.FieldType.string }),
|
AddCol({ name: 'extraclass', label_trans: 'pages.extraclass', fieldtype: costanti.FieldType.string }),
|
||||||
@@ -1436,6 +1448,8 @@ export const colTableSites = [
|
|||||||
AddCol({ name: 'domain_provider', label_trans: 'sites.domain_provider', fieldtype: costanti.FieldType.string }),
|
AddCol({ name: 'domain_provider', label_trans: 'sites.domain_provider', fieldtype: costanti.FieldType.string }),
|
||||||
AddCol({ name: 'domain_expiring', label_trans: 'reg.domain_expiring', fieldtype: costanti.FieldType.onlydate }),
|
AddCol({ name: 'domain_expiring', label_trans: 'reg.domain_expiring', fieldtype: costanti.FieldType.onlydate }),
|
||||||
AddCol({ name: 'next_payment', label_trans: 'reg.next_payment', fieldtype: costanti.FieldType.onlydate }),
|
AddCol({ name: 'next_payment', label_trans: 'reg.next_payment', fieldtype: costanti.FieldType.onlydate }),
|
||||||
|
AddCol({ name: 'description', label_trans: 'reg.description' }),
|
||||||
|
AddCol({ name: 'keywords', label_trans: 'reg.keywords' }),
|
||||||
// Configuration
|
// Configuration
|
||||||
// AddCol({ name: 'confsite.notif_reg', field: 'confsite', subfield: 'notif_reg', label_trans: 'reg.notif_reg', fieldtype: costanti.FieldType.boolean }),
|
// AddCol({ name: 'confsite.notif_reg', field: 'confsite', subfield: 'notif_reg', label_trans: 'reg.notif_reg', fieldtype: costanti.FieldType.boolean }),
|
||||||
AddCol({
|
AddCol({
|
||||||
@@ -3040,6 +3054,20 @@ export const fieldsTable = {
|
|||||||
colkey: '_id',
|
colkey: '_id',
|
||||||
collabel: 'title',
|
collabel: 'title',
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
value: 'listcards',
|
||||||
|
label: 'Elementi',
|
||||||
|
columns: colmylistcards,
|
||||||
|
colkey: '_id',
|
||||||
|
collabel: 'imagefile',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
value: 'imgcards',
|
||||||
|
label: 'Img',
|
||||||
|
columns: colmylistcards,
|
||||||
|
colkey: '_id',
|
||||||
|
collabel: 'imagefile',
|
||||||
|
},
|
||||||
{
|
{
|
||||||
value: 'templemail',
|
value: 'templemail',
|
||||||
label: 'Template Email',
|
label: 'Template Email',
|
||||||
|
|||||||
@@ -15,6 +15,8 @@ import {
|
|||||||
TipoVisu, IGroup, IMySkill, IMyBacheca, IImgGallery, IMsgGlobParam, IUserExport, ISpecialField, IAccount, IMyCircuit, ISendCoin, IMovement, IMovVisu, INotif,
|
TipoVisu, IGroup, IMySkill, IMyBacheca, IImgGallery, IMsgGlobParam, IUserExport, ISpecialField, IAccount, IMyCircuit, ISendCoin, IMovement, IMovVisu, INotif,
|
||||||
} from '@model'
|
} from '@model'
|
||||||
|
|
||||||
|
import { fieldsTable } from '@store/Modules/fieldsTable'
|
||||||
|
|
||||||
import { addToDate } from '@quasar/quasar-ui-qcalendar'
|
import { addToDate } from '@quasar/quasar-ui-qcalendar'
|
||||||
|
|
||||||
import { lists } from '@store/Modules/lists'
|
import { lists } from '@store/Modules/lists'
|
||||||
@@ -293,168 +295,168 @@ export const tools = {
|
|||||||
],
|
],
|
||||||
|
|
||||||
SelectListColors: [
|
SelectListColors: [
|
||||||
{label: '[Nessuno]', value: ''},
|
{ label: '[Nessuno]', value: '' },
|
||||||
{label: 'aliceblue', value: '#f0f8ff'},
|
{ label: 'aliceblue', value: '#f0f8ff' },
|
||||||
{label: 'antiquewhite', value: '#faebd7'},
|
{ label: 'antiquewhite', value: '#faebd7' },
|
||||||
{label: 'aqua', value: '#00ffff'},
|
{ label: 'aqua', value: '#00ffff' },
|
||||||
{label: 'aquamarine', value: '#7fffd4'},
|
{ label: 'aquamarine', value: '#7fffd4' },
|
||||||
{label: 'azure', value: '#f0ffff'},
|
{ label: 'azure', value: '#f0ffff' },
|
||||||
{label: 'beige', value: '#f5f5dc'},
|
{ label: 'beige', value: '#f5f5dc' },
|
||||||
{label: 'bisque', value: '#ffe4c4'},
|
{ label: 'bisque', value: '#ffe4c4' },
|
||||||
{label: 'black', value: '#000000'},
|
{ label: 'black', value: '#000000' },
|
||||||
{label: 'blanchedalmond', value: '#ffebcd'},
|
{ label: 'blanchedalmond', value: '#ffebcd' },
|
||||||
{label: 'blue', value: '#0000ff'},
|
{ label: 'blue', value: '#0000ff' },
|
||||||
{label: 'blue-3', value: '#90caf9'},
|
{ label: 'blue-3', value: '#90caf9' },
|
||||||
{label: 'blue-4', value: '#64b5f6'},
|
{ label: 'blue-4', value: '#64b5f6' },
|
||||||
{label: 'amber-10', value: '#ff6f00'},
|
{ label: 'amber-10', value: '#ff6f00' },
|
||||||
{label: 'blue-6', value: '#2196f3'},
|
{ label: 'blue-6', value: '#2196f3' },
|
||||||
{label: 'blueviolet', value: '#8a2be2'},
|
{ label: 'blueviolet', value: '#8a2be2' },
|
||||||
{label: 'brown', value: '#a52a2a'},
|
{ label: 'brown', value: '#a52a2a' },
|
||||||
{label: 'burlywood', value: '#deb887'},
|
{ label: 'burlywood', value: '#deb887' },
|
||||||
{label: 'cadetblue', value: '#5f9ea0'},
|
{ label: 'cadetblue', value: '#5f9ea0' },
|
||||||
{label: 'chartreuse', value: '#7fff00'},
|
{ label: 'chartreuse', value: '#7fff00' },
|
||||||
{label: 'chocolate', value: '#d2691e'},
|
{ label: 'chocolate', value: '#d2691e' },
|
||||||
{label: 'coral', value: '#ff7f50'},
|
{ label: 'coral', value: '#ff7f50' },
|
||||||
{label: 'cornflowerblue', value: '#6495ed'},
|
{ label: 'cornflowerblue', value: '#6495ed' },
|
||||||
{label: 'cornsilk', value: '#fff8dc'},
|
{ label: 'cornsilk', value: '#fff8dc' },
|
||||||
{label: 'crimson', value: '#dc143c'},
|
{ label: 'crimson', value: '#dc143c' },
|
||||||
{label: 'cyan', value: '#00ffff'},
|
{ label: 'cyan', value: '#00ffff' },
|
||||||
{label: 'darkblue', value: '#00008b'},
|
{ label: 'darkblue', value: '#00008b' },
|
||||||
{label: 'darkcyan', value: '#008b8b'},
|
{ label: 'darkcyan', value: '#008b8b' },
|
||||||
{label: 'darkgoldenrod', value: '#b8860b'},
|
{ label: 'darkgoldenrod', value: '#b8860b' },
|
||||||
{label: 'darkgray', value: '#a9a9a9'},
|
{ label: 'darkgray', value: '#a9a9a9' },
|
||||||
{label: 'darkgreen', value: '#006400'},
|
{ label: 'darkgreen', value: '#006400' },
|
||||||
{label: 'darkkhaki', value: '#bdb76b'},
|
{ label: 'darkkhaki', value: '#bdb76b' },
|
||||||
{label: 'darkmagenta', value: '#8b008b'},
|
{ label: 'darkmagenta', value: '#8b008b' },
|
||||||
{label: 'darkolivegreen', value: '#556b2f'},
|
{ label: 'darkolivegreen', value: '#556b2f' },
|
||||||
{label: 'darkorange', value: '#ff8c00'},
|
{ label: 'darkorange', value: '#ff8c00' },
|
||||||
{label: 'darkorchid', value: '#9932cc'},
|
{ label: 'darkorchid', value: '#9932cc' },
|
||||||
{label: 'darkred', value: '#8b0000'},
|
{ label: 'darkred', value: '#8b0000' },
|
||||||
{label: 'darksalmon', value: '#e9967a'},
|
{ label: 'darksalmon', value: '#e9967a' },
|
||||||
{label: 'darkseagreen', value: '#8fbc8f'},
|
{ label: 'darkseagreen', value: '#8fbc8f' },
|
||||||
{label: 'darkslateblue', value: '#483d8b'},
|
{ label: 'darkslateblue', value: '#483d8b' },
|
||||||
{label: 'darkslategray', value: '#2f4f4f'},
|
{ label: 'darkslategray', value: '#2f4f4f' },
|
||||||
{label: 'darkturquoise', value: '#00ced1'},
|
{ label: 'darkturquoise', value: '#00ced1' },
|
||||||
{label: 'darkviolet', value: '#9400d3'},
|
{ label: 'darkviolet', value: '#9400d3' },
|
||||||
{label: 'deeppink', value: '#ff1493'},
|
{ label: 'deeppink', value: '#ff1493' },
|
||||||
{label: 'deepskyblue', value: '#00bfff'},
|
{ label: 'deepskyblue', value: '#00bfff' },
|
||||||
{label: 'dimgray', value: '#696969'},
|
{ label: 'dimgray', value: '#696969' },
|
||||||
{label: 'dodgerblue', value: '#1e90ff'},
|
{ label: 'dodgerblue', value: '#1e90ff' },
|
||||||
{label: 'firebrick', value: '#b22222'},
|
{ label: 'firebrick', value: '#b22222' },
|
||||||
{label: 'floralwhite', value: '#fffaf0'},
|
{ label: 'floralwhite', value: '#fffaf0' },
|
||||||
{label: 'forestgreen', value: '#228b22'},
|
{ label: 'forestgreen', value: '#228b22' },
|
||||||
{label: 'fuchsia', value: '#ff00ff'},
|
{ label: 'fuchsia', value: '#ff00ff' },
|
||||||
{label: 'gainsboro', value: '#dcdcdc'},
|
{ label: 'gainsboro', value: '#dcdcdc' },
|
||||||
{label: 'ghostwhite', value: '#f8f8ff'},
|
{ label: 'ghostwhite', value: '#f8f8ff' },
|
||||||
{label: 'gold', value: '#ffd700'},
|
{ label: 'gold', value: '#ffd700' },
|
||||||
{label: 'goldenrod', value: '#daa520'},
|
{ label: 'goldenrod', value: '#daa520' },
|
||||||
{label: 'gray', value: '#808080'},
|
{ label: 'gray', value: '#808080' },
|
||||||
{label: 'green', value: '#008000'},
|
{ label: 'green', value: '#008000' },
|
||||||
{label: 'green-3', value: '#a5d6a7'},
|
{ label: 'green-3', value: '#a5d6a7' },
|
||||||
{label: 'green-4', value: '#81c784'},
|
{ label: 'green-4', value: '#81c784' },
|
||||||
{label: 'green-6', value: '#4caf50'},
|
{ label: 'green-6', value: '#4caf50' },
|
||||||
{label: 'greenyellow', value: '#adff2f'},
|
{ label: 'greenyellow', value: '#adff2f' },
|
||||||
{label: 'honeydew', value: '#f0fff0'},
|
{ label: 'honeydew', value: '#f0fff0' },
|
||||||
{label: 'hotpink', value: '#ff69b4'},
|
{ label: 'hotpink', value: '#ff69b4' },
|
||||||
{label: 'indianred ', value: '#cd5c5c'},
|
{ label: 'indianred ', value: '#cd5c5c' },
|
||||||
{label: 'indigo-3', value: '#9fa8da'},
|
{ label: 'indigo-3', value: '#9fa8da' },
|
||||||
{label: 'indigo-4', value: '#7986cb'},
|
{ label: 'indigo-4', value: '#7986cb' },
|
||||||
{label: 'indigo-6', value: '#3f51b5'},
|
{ label: 'indigo-6', value: '#3f51b5' },
|
||||||
{label: 'indigo', value: '#4b0082'},
|
{ label: 'indigo', value: '#4b0082' },
|
||||||
{label: 'ivory', value: '#fffff0'},
|
{ label: 'ivory', value: '#fffff0' },
|
||||||
{label: 'khaki', value: '#f0e68c'},
|
{ label: 'khaki', value: '#f0e68c' },
|
||||||
{label: 'lavender', value: '#e6e6fa'},
|
{ label: 'lavender', value: '#e6e6fa' },
|
||||||
{label: 'lavenderblush', value: '#fff0f5'},
|
{ label: 'lavenderblush', value: '#fff0f5' },
|
||||||
{label: 'lawngreen', value: '#7cfc00'},
|
{ label: 'lawngreen', value: '#7cfc00' },
|
||||||
{label: 'lemonchiffon', value: '#fffacd'},
|
{ label: 'lemonchiffon', value: '#fffacd' },
|
||||||
{label: 'lightblue', value: '#add8e6'},
|
{ label: 'lightblue', value: '#add8e6' },
|
||||||
{label: 'lightcoral', value: '#f08080'},
|
{ label: 'lightcoral', value: '#f08080' },
|
||||||
{label: 'lightcyan', value: '#e0ffff'},
|
{ label: 'lightcyan', value: '#e0ffff' },
|
||||||
{label: 'lightgoldenrodyellow', value: '#fafad2'},
|
{ label: 'lightgoldenrodyellow', value: '#fafad2' },
|
||||||
{label: 'lightgrey', value: '#d3d3d3'},
|
{ label: 'lightgrey', value: '#d3d3d3' },
|
||||||
{label: 'lightgreen', value: '#90ee90'},
|
{ label: 'lightgreen', value: '#90ee90' },
|
||||||
{label: 'lightpink', value: '#ffb6c1'},
|
{ label: 'lightpink', value: '#ffb6c1' },
|
||||||
{label: 'lightsalmon', value: '#ffa07a'},
|
{ label: 'lightsalmon', value: '#ffa07a' },
|
||||||
{label: 'lightseagreen', value: '#20b2aa'},
|
{ label: 'lightseagreen', value: '#20b2aa' },
|
||||||
{label: 'lightskyblue', value: '#87cefa'},
|
{ label: 'lightskyblue', value: '#87cefa' },
|
||||||
{label: 'lightslategray', value: '#778899'},
|
{ label: 'lightslategray', value: '#778899' },
|
||||||
{label: 'lightsteelblue', value: '#b0c4de'},
|
{ label: 'lightsteelblue', value: '#b0c4de' },
|
||||||
{label: 'lightyellow', value: '#ffffe0'},
|
{ label: 'lightyellow', value: '#ffffe0' },
|
||||||
{label: 'lime', value: '#00ff00'},
|
{ label: 'lime', value: '#00ff00' },
|
||||||
{label: 'lime-3', value: '#e6ee9c'},
|
{ label: 'lime-3', value: '#e6ee9c' },
|
||||||
{label: 'lime-4', value: '#dce775'},
|
{ label: 'lime-4', value: '#dce775' },
|
||||||
{label: 'lime-6', value: '#cddc39'},
|
{ label: 'lime-6', value: '#cddc39' },
|
||||||
{label: 'lime-8', value: '#afb42b'},
|
{ label: 'lime-8', value: '#afb42b' },
|
||||||
{label: 'limegreen', value: '#32cd32'},
|
{ label: 'limegreen', value: '#32cd32' },
|
||||||
{label: 'linen', value: '#faf0e6'},
|
{ label: 'linen', value: '#faf0e6' },
|
||||||
{label: 'magenta', value: '#ff00ff'},
|
{ label: 'magenta', value: '#ff00ff' },
|
||||||
{label: 'maroon', value: '#800000'},
|
{ label: 'maroon', value: '#800000' },
|
||||||
{label: 'mediumaquamarine', value: '#66cdaa'},
|
{ label: 'mediumaquamarine', value: '#66cdaa' },
|
||||||
{label: 'mediumblue', value: '#0000cd'},
|
{ label: 'mediumblue', value: '#0000cd' },
|
||||||
{label: 'mediumorchid', value: '#ba55d3'},
|
{ label: 'mediumorchid', value: '#ba55d3' },
|
||||||
{label: 'mediumpurple', value: '#9370d8'},
|
{ label: 'mediumpurple', value: '#9370d8' },
|
||||||
{label: 'mediumseagreen', value: '#3cb371'},
|
{ label: 'mediumseagreen', value: '#3cb371' },
|
||||||
{label: 'mediumslateblue', value: '#7b68ee'},
|
{ label: 'mediumslateblue', value: '#7b68ee' },
|
||||||
{label: 'mediumspringgreen', value: '#00fa9a'},
|
{ label: 'mediumspringgreen', value: '#00fa9a' },
|
||||||
{label: 'mediumturquoise', value: '#48d1cc'},
|
{ label: 'mediumturquoise', value: '#48d1cc' },
|
||||||
{label: 'mediumvioletred', value: '#c71585'},
|
{ label: 'mediumvioletred', value: '#c71585' },
|
||||||
{label: 'midnightblue', value: '#191970'},
|
{ label: 'midnightblue', value: '#191970' },
|
||||||
{label: 'mintcream', value: '#f5fffa'},
|
{ label: 'mintcream', value: '#f5fffa' },
|
||||||
{label: 'mistyrose', value: '#ffe4e1'},
|
{ label: 'mistyrose', value: '#ffe4e1' },
|
||||||
{label: 'moccasin', value: '#ffe4b5'},
|
{ label: 'moccasin', value: '#ffe4b5' },
|
||||||
{label: 'navajowhite', value: '#ffdead'},
|
{ label: 'navajowhite', value: '#ffdead' },
|
||||||
{label: 'navy', value: '#000080'},
|
{ label: 'navy', value: '#000080' },
|
||||||
{label: 'oldlace', value: '#fdf5e6'},
|
{ label: 'oldlace', value: '#fdf5e6' },
|
||||||
{label: 'olive', value: '#808000'},
|
{ label: 'olive', value: '#808000' },
|
||||||
{label: 'olivedrab', value: '#6b8e23'},
|
{ label: 'olivedrab', value: '#6b8e23' },
|
||||||
{label: 'orange', value: '#ffa500'},
|
{ label: 'orange', value: '#ffa500' },
|
||||||
{label: 'orange-3', value: '#ffcc80'},
|
{ label: 'orange-3', value: '#ffcc80' },
|
||||||
{label: 'orange-4', value: '#ffb74d'},
|
{ label: 'orange-4', value: '#ffb74d' },
|
||||||
{label: 'orange-6', value: '#ff9800'},
|
{ label: 'orange-6', value: '#ff9800' },
|
||||||
{label: 'orangered', value: '#ff4500'},
|
{ label: 'orangered', value: '#ff4500' },
|
||||||
{label: 'orchid', value: '#da70d6'},
|
{ label: 'orchid', value: '#da70d6' },
|
||||||
{label: 'palegoldenrod', value: '#eee8aa'},
|
{ label: 'palegoldenrod', value: '#eee8aa' },
|
||||||
{label: 'palegreen', value: '#98fb98'},
|
{ label: 'palegreen', value: '#98fb98' },
|
||||||
{label: 'paleturquoise', value: '#afeeee'},
|
{ label: 'paleturquoise', value: '#afeeee' },
|
||||||
{label: 'palevioletred', value: '#d87093'},
|
{ label: 'palevioletred', value: '#d87093' },
|
||||||
{label: 'papayawhip', value: '#ffefd5'},
|
{ label: 'papayawhip', value: '#ffefd5' },
|
||||||
{label: 'peachpuff', value: '#ffdab9'},
|
{ label: 'peachpuff', value: '#ffdab9' },
|
||||||
{label: 'peru', value: '#cd853f'},
|
{ label: 'peru', value: '#cd853f' },
|
||||||
{label: 'pink', value: '#ffc0cb'},
|
{ label: 'pink', value: '#ffc0cb' },
|
||||||
{label: 'plum', value: '#dda0dd'},
|
{ label: 'plum', value: '#dda0dd' },
|
||||||
{label: 'powderblue', value: '#b0e0e6'},
|
{ label: 'powderblue', value: '#b0e0e6' },
|
||||||
{label: 'purple', value: '#800080'},
|
{ label: 'purple', value: '#800080' },
|
||||||
{label: 'rebeccapurple', value: '#663399'},
|
{ label: 'rebeccapurple', value: '#663399' },
|
||||||
{label: 'red', value: '#ff0000'},
|
{ label: 'red', value: '#ff0000' },
|
||||||
{label: 'red-3', value: '#ef9a9a'},
|
{ label: 'red-3', value: '#ef9a9a' },
|
||||||
{label: 'red-4', value: '#e57373'},
|
{ label: 'red-4', value: '#e57373' },
|
||||||
{label: 'red-6', value: '#f44336'},
|
{ label: 'red-6', value: '#f44336' },
|
||||||
{label: 'rosybrown', value: '#bc8f8f'},
|
{ label: 'rosybrown', value: '#bc8f8f' },
|
||||||
{label: 'royalblue', value: '#4169e1'},
|
{ label: 'royalblue', value: '#4169e1' },
|
||||||
{label: 'saddlebrown', value: '#8b4513'},
|
{ label: 'saddlebrown', value: '#8b4513' },
|
||||||
{label: 'salmon', value: '#fa8072'},
|
{ label: 'salmon', value: '#fa8072' },
|
||||||
{label: 'sandybrown', value: '#f4a460'},
|
{ label: 'sandybrown', value: '#f4a460' },
|
||||||
{label: 'seagreen', value: '#2e8b57'},
|
{ label: 'seagreen', value: '#2e8b57' },
|
||||||
{label: 'seashell', value: '#fff5ee'},
|
{ label: 'seashell', value: '#fff5ee' },
|
||||||
{label: 'sienna', value: '#a0522d'},
|
{ label: 'sienna', value: '#a0522d' },
|
||||||
{label: 'silver', value: '#c0c0c0'},
|
{ label: 'silver', value: '#c0c0c0' },
|
||||||
{label: 'skyblue', value: '#87ceeb'},
|
{ label: 'skyblue', value: '#87ceeb' },
|
||||||
{label: 'slateblue', value: '#6a5acd'},
|
{ label: 'slateblue', value: '#6a5acd' },
|
||||||
{label: 'slategray', value: '#708090'},
|
{ label: 'slategray', value: '#708090' },
|
||||||
{label: 'snow', value: '#fffafa'},
|
{ label: 'snow', value: '#fffafa' },
|
||||||
{label: 'springgreen', value: '#00ff7f'},
|
{ label: 'springgreen', value: '#00ff7f' },
|
||||||
{label: 'steelblue', value: '#4682b4'},
|
{ label: 'steelblue', value: '#4682b4' },
|
||||||
{label: 'tan', value: '#d2b48c'},
|
{ label: 'tan', value: '#d2b48c' },
|
||||||
{label: 'teal', value: '#008080'},
|
{ label: 'teal', value: '#008080' },
|
||||||
{label: 'thistle', value: '#d8bfd8'},
|
{ label: 'thistle', value: '#d8bfd8' },
|
||||||
{label: 'tomato', value: '#ff6347'},
|
{ label: 'tomato', value: '#ff6347' },
|
||||||
{label: 'turquoise', value: '#40e0d0'},
|
{ label: 'turquoise', value: '#40e0d0' },
|
||||||
{label: 'violet', value: '#ee82ee'},
|
{ label: 'violet', value: '#ee82ee' },
|
||||||
{label: 'wheat', value: '#f5deb3'},
|
{ label: 'wheat', value: '#f5deb3' },
|
||||||
{label: 'white', value: '#ffffff'},
|
{ label: 'white', value: '#ffffff' },
|
||||||
{label: 'whitesmoke', value: '#f5f5f5'},
|
{ label: 'whitesmoke', value: '#f5f5f5' },
|
||||||
{label: 'yellow', value: '#ffff00'},
|
{ label: 'yellow', value: '#ffff00' },
|
||||||
{label: 'yellowgreen', value: '#9acd32'},
|
{ label: 'yellowgreen', value: '#9acd32' },
|
||||||
],
|
],
|
||||||
|
|
||||||
SelectQuotaVersata: [
|
SelectQuotaVersata: [
|
||||||
@@ -954,32 +956,108 @@ export const tools = {
|
|||||||
INDEX_MENU_DELETE: 4,
|
INDEX_MENU_DELETE: 4,
|
||||||
|
|
||||||
menuPopupTodo:
|
menuPopupTodo:
|
||||||
{
|
{
|
||||||
it: [
|
it: [
|
||||||
|
{
|
||||||
|
id: 5,
|
||||||
|
disable: false,
|
||||||
|
label: 'Taglia',
|
||||||
|
value: lists.MenuAction.CUT,
|
||||||
|
icon: 'undo',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 10,
|
||||||
|
disable: false,
|
||||||
|
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,
|
||||||
|
label: '',
|
||||||
|
value: lists.MenuAction.PROGRESS_BAR,
|
||||||
|
icon: 'rowing',
|
||||||
|
checked: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 20,
|
||||||
|
disable: false,
|
||||||
|
label: 'Imposta Priorità',
|
||||||
|
value: lists.MenuAction.PRIORITY,
|
||||||
|
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,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 30,
|
||||||
|
disable: false,
|
||||||
|
label: 'Completato',
|
||||||
|
value: lists.MenuAction.COMPLETED,
|
||||||
|
icon: 'check_circle',
|
||||||
|
checked: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 40,
|
||||||
|
disable: false,
|
||||||
|
label: 'Imposta Scadenza',
|
||||||
|
value: lists.MenuAction.TOGGLE_EXPIRING,
|
||||||
|
icon: 'date_range',
|
||||||
|
checked: true,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
es:
|
||||||
|
[
|
||||||
{
|
{
|
||||||
id: 5,
|
id: 5,
|
||||||
disable: false,
|
disable: false,
|
||||||
label: 'Taglia',
|
label: 'Cortar',
|
||||||
value: lists.MenuAction.CUT,
|
value: lists.MenuAction.CUT,
|
||||||
icon: 'undo',
|
icon: 'undo',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
id: 10,
|
id: 7,
|
||||||
disable: false,
|
disable: false,
|
||||||
label: 'Modifica',
|
label: 'Editar',
|
||||||
value: lists.MenuAction.EDIT,
|
value: lists.MenuAction.EDIT,
|
||||||
icon: 'create',
|
icon: 'create',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
id: 11,
|
id: 8,
|
||||||
disable: false,
|
disable: false,
|
||||||
label: 'Elimina',
|
label: 'Borrar',
|
||||||
value: lists.MenuAction.DELETE,
|
value: lists.MenuAction.DELETE,
|
||||||
icon: 'delete',
|
icon: 'delete',
|
||||||
checked: false,
|
checked: false,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
id: 12,
|
id: 10,
|
||||||
disable: false,
|
disable: false,
|
||||||
label: '',
|
label: '',
|
||||||
value: lists.MenuAction.PROGRESS_BAR,
|
value: lists.MenuAction.PROGRESS_BAR,
|
||||||
@@ -989,16 +1067,16 @@ export const tools = {
|
|||||||
{
|
{
|
||||||
id: 20,
|
id: 20,
|
||||||
disable: false,
|
disable: false,
|
||||||
label: 'Imposta Priorità',
|
label: 'Establecer Prioridad',
|
||||||
value: lists.MenuAction.PRIORITY,
|
value: lists.MenuAction.PRIORITY,
|
||||||
icon: 'rowing',
|
icon: 'rowing',
|
||||||
checked: false,
|
checked: false,
|
||||||
arrlista: lists.selectPriority.it,
|
arrlista: lists.selectPriority.es,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
id: 21,
|
id: 21,
|
||||||
disable: false,
|
disable: false,
|
||||||
label: translation.it.proj.themecolor,
|
label: translation.es.proj.themecolor,
|
||||||
value: lists.MenuAction.THEME,
|
value: lists.MenuAction.THEME,
|
||||||
icon: 'format_color_text',
|
icon: 'format_color_text',
|
||||||
checked: false,
|
checked: false,
|
||||||
@@ -1007,7 +1085,7 @@ export const tools = {
|
|||||||
{
|
{
|
||||||
id: 22,
|
id: 22,
|
||||||
disable: false,
|
disable: false,
|
||||||
label: translation.it.proj.themebgcolor,
|
label: translation.es.proj.themebgcolor,
|
||||||
value: lists.MenuAction.THEMEBG,
|
value: lists.MenuAction.THEMEBG,
|
||||||
icon: 'format_color_fill',
|
icon: 'format_color_fill',
|
||||||
checked: false,
|
checked: false,
|
||||||
@@ -1016,7 +1094,7 @@ export const tools = {
|
|||||||
{
|
{
|
||||||
id: 30,
|
id: 30,
|
||||||
disable: false,
|
disable: false,
|
||||||
label: 'Completato',
|
label: 'Completado',
|
||||||
value: lists.MenuAction.COMPLETED,
|
value: lists.MenuAction.COMPLETED,
|
||||||
icon: 'check_circle',
|
icon: 'check_circle',
|
||||||
checked: true,
|
checked: true,
|
||||||
@@ -1024,165 +1102,89 @@ export const tools = {
|
|||||||
{
|
{
|
||||||
id: 40,
|
id: 40,
|
||||||
disable: false,
|
disable: false,
|
||||||
label: 'Imposta Scadenza',
|
label: 'Establecer expiración',
|
||||||
value: lists.MenuAction.TOGGLE_EXPIRING,
|
value: lists.MenuAction.TOGGLE_EXPIRING,
|
||||||
icon: 'date_range',
|
icon: 'date_range',
|
||||||
checked: true,
|
checked: true,
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
es:
|
enUs:
|
||||||
[
|
[
|
||||||
{
|
{
|
||||||
id: 5,
|
id: 5,
|
||||||
disable: false,
|
disable: false,
|
||||||
label: 'Cortar',
|
label: 'Cut',
|
||||||
value: lists.MenuAction.CUT,
|
value: lists.MenuAction.CUT,
|
||||||
icon: 'undo',
|
icon: 'undo',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
id: 7,
|
id: 7,
|
||||||
disable: false,
|
disable: false,
|
||||||
label: 'Editar',
|
label: 'Edit',
|
||||||
value: lists.MenuAction.EDIT,
|
value: lists.MenuAction.EDIT,
|
||||||
icon: 'create',
|
icon: 'create',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
id: 8,
|
id: 8,
|
||||||
disable: false,
|
disable: false,
|
||||||
label: 'Borrar',
|
label: 'Delete',
|
||||||
value: lists.MenuAction.DELETE,
|
value: lists.MenuAction.DELETE,
|
||||||
icon: 'delete',
|
icon: 'trash',
|
||||||
checked: false,
|
checked: false,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
id: 10,
|
id: 10,
|
||||||
disable: false,
|
disable: false,
|
||||||
label: '',
|
label: '',
|
||||||
value: lists.MenuAction.PROGRESS_BAR,
|
value: lists.MenuAction.PROGRESS_BAR,
|
||||||
icon: 'rowing',
|
icon: 'check_circle',
|
||||||
checked: true,
|
checked: true,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
id: 20,
|
id: 20,
|
||||||
disable: false,
|
disable: false,
|
||||||
label: 'Establecer Prioridad',
|
label: 'Set Priority',
|
||||||
value: lists.MenuAction.PRIORITY,
|
value: lists.MenuAction.PRIORITY,
|
||||||
icon: 'rowing',
|
icon: 'high_priority',
|
||||||
checked: false,
|
checked: false,
|
||||||
arrlista: lists.selectPriority.es,
|
arrlista: lists.selectPriority.enUs,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
id: 21,
|
id: 21,
|
||||||
disable: false,
|
disable: false,
|
||||||
label: translation.es.proj.themecolor,
|
label: translation.enUs.proj.themecolor,
|
||||||
value: lists.MenuAction.THEME,
|
value: lists.MenuAction.THEME,
|
||||||
icon: 'format_color_text',
|
icon: 'format_color_text',
|
||||||
checked: false,
|
checked: false,
|
||||||
arrlista: lists.selectTheme,
|
arrlista: lists.selectTheme,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
id: 22,
|
id: 22,
|
||||||
disable: false,
|
disable: false,
|
||||||
label: translation.es.proj.themebgcolor,
|
label: translation.enUs.proj.themebgcolor,
|
||||||
value: lists.MenuAction.THEMEBG,
|
value: lists.MenuAction.THEMEBG,
|
||||||
icon: 'format_color_fill',
|
icon: 'format_color_fill',
|
||||||
checked: false,
|
checked: false,
|
||||||
arrlista: lists.selectTheme,
|
arrlista: lists.selectTheme,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
id: 30,
|
id: 30,
|
||||||
disable: false,
|
disable: false,
|
||||||
label: 'Completado',
|
label: 'Completed',
|
||||||
value: lists.MenuAction.COMPLETED,
|
value: lists.MenuAction.COMPLETED,
|
||||||
icon: 'check_circle',
|
icon: 'check_circle',
|
||||||
checked: true,
|
checked: true,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
id: 40,
|
id: 40,
|
||||||
disable: false,
|
disable: false,
|
||||||
label: 'Establecer expiración',
|
label: 'Set Expiring',
|
||||||
value: lists.MenuAction.TOGGLE_EXPIRING,
|
value: lists.MenuAction.TOGGLE_EXPIRING,
|
||||||
icon: 'date_range',
|
icon: 'date_range',
|
||||||
checked: true,
|
checked: true,
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
enUs:
|
},
|
||||||
[
|
|
||||||
{
|
|
||||||
id: 5,
|
|
||||||
disable: false,
|
|
||||||
label: 'Cut',
|
|
||||||
value: lists.MenuAction.CUT,
|
|
||||||
icon: 'undo',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
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,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: 10,
|
|
||||||
disable: false,
|
|
||||||
label: '',
|
|
||||||
value: lists.MenuAction.PROGRESS_BAR,
|
|
||||||
icon: 'check_circle',
|
|
||||||
checked: true,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: 20,
|
|
||||||
disable: false,
|
|
||||||
label: 'Set Priority',
|
|
||||||
value: lists.MenuAction.PRIORITY,
|
|
||||||
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,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: 30,
|
|
||||||
disable: false,
|
|
||||||
label: 'Completed',
|
|
||||||
value: lists.MenuAction.COMPLETED,
|
|
||||||
icon: 'check_circle',
|
|
||||||
checked: true,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: 40,
|
|
||||||
disable: false,
|
|
||||||
label: 'Set Expiring',
|
|
||||||
value: lists.MenuAction.TOGGLE_EXPIRING,
|
|
||||||
icon: 'date_range',
|
|
||||||
checked: true,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
},
|
|
||||||
|
|
||||||
menuPopupProj: {
|
menuPopupProj: {
|
||||||
it: [
|
it: [
|
||||||
@@ -2321,7 +2323,7 @@ export const tools = {
|
|||||||
this.showNotif(q, msg, { color: 'info', icon: 'notifications' }, time)
|
this.showNotif(q, msg, { color: 'info', icon: 'notifications' }, time)
|
||||||
},
|
},
|
||||||
|
|
||||||
showNotif(q: any, msg: string, data ?: INotify | null, time?: number) {
|
showNotif(q: any, msg: string, data?: INotify | null, time?: number) {
|
||||||
let myicon = data ? data.icon : 'ion-add'
|
let myicon = data ? data.icon : 'ion-add'
|
||||||
if (!myicon) {
|
if (!myicon) {
|
||||||
myicon = 'ion-add'
|
myicon = 'ion-add'
|
||||||
@@ -2965,7 +2967,7 @@ export const tools = {
|
|||||||
return idproj === process.env.PROJECT_ID_MAIN
|
return idproj === process.env.PROJECT_ID_MAIN
|
||||||
},
|
},
|
||||||
|
|
||||||
getUrlByTipoProj(tipoproj: string, name ?: string) {
|
getUrlByTipoProj(tipoproj: string, name?: string) {
|
||||||
if (name) return `/${name}/`
|
if (name) return `/${name}/`
|
||||||
return `/${tipoproj}/`
|
return `/${tipoproj}/`
|
||||||
},
|
},
|
||||||
@@ -3136,7 +3138,7 @@ export const tools = {
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
styles_imgtitle(sized ?: string) {
|
styles_imgtitle(sized?: string) {
|
||||||
if (!!sized) {
|
if (!!sized) {
|
||||||
return sized
|
return sized
|
||||||
} else {
|
} else {
|
||||||
@@ -3227,7 +3229,7 @@ export const tools = {
|
|||||||
}
|
}
|
||||||
,
|
,
|
||||||
|
|
||||||
getLocale(vero ?: boolean) {
|
getLocale(vero?: boolean) {
|
||||||
const userStore = useUserStore()
|
const userStore = useUserStore()
|
||||||
if (userStore) {
|
if (userStore) {
|
||||||
if (userStore) {
|
if (userStore) {
|
||||||
@@ -3282,7 +3284,7 @@ export const tools = {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
,
|
,
|
||||||
gettextdescr(data: {[index: string]: any}, numdescr = 'description',
|
gettextdescr(data: { [index: string]: any }, numdescr = 'description',
|
||||||
) {
|
) {
|
||||||
if (!!data[numdescr]) {
|
if (!!data[numdescr]) {
|
||||||
if (data[numdescr][toolsext.getLocale()])
|
if (data[numdescr][toolsext.getLocale()])
|
||||||
@@ -3438,7 +3440,7 @@ export const tools = {
|
|||||||
return arr[0] + '//' + arr[2]
|
return arr[0] + '//' + arr[2]
|
||||||
},
|
},
|
||||||
|
|
||||||
SignIncheckErrors(mythisq: any, $router: Router, route: any, riscode: any, ispageLogin ?: boolean) {
|
SignIncheckErrors(mythisq: any, $router: Router, route: any, riscode: any, ispageLogin?: boolean) {
|
||||||
console.log('SignIncheckErrors: ', riscode)
|
console.log('SignIncheckErrors: ', riscode)
|
||||||
const $q = useQuasar()
|
const $q = useQuasar()
|
||||||
|
|
||||||
@@ -3846,23 +3848,6 @@ export const tools = {
|
|||||||
return ''
|
return ''
|
||||||
},
|
},
|
||||||
|
|
||||||
metafunc(mythis: any) {
|
|
||||||
return {
|
|
||||||
title: mythis.t('ws.sitename'),
|
|
||||||
titleTemplate: (title: any) => `${this.getsuffisso()} ${mythis.mymeta.title} - ${mythis.t('ws.sitename')}`,
|
|
||||||
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' },
|
|
||||||
},
|
|
||||||
}
|
|
||||||
},
|
|
||||||
geturlupload() {
|
geturlupload() {
|
||||||
return tools.getServerHost() + `/uploadnew/${this.getvers()}/`
|
return tools.getServerHost() + `/uploadnew/${this.getvers()}/`
|
||||||
},
|
},
|
||||||
@@ -6782,7 +6767,78 @@ export const tools = {
|
|||||||
return (Math.round(mynum * 100) / 100)
|
return (Math.round(mynum * 100) / 100)
|
||||||
},
|
},
|
||||||
|
|
||||||
// getLocale() {
|
getheightgallery() {
|
||||||
|
if (this.isMobile()) {
|
||||||
|
if (Screen.height < 700) {
|
||||||
|
return '400px'
|
||||||
|
} else {
|
||||||
|
return '500px'
|
||||||
|
}
|
||||||
|
|
||||||
|
} else {
|
||||||
|
if (Screen.width < 1200) {
|
||||||
|
return '500px'
|
||||||
|
} else {
|
||||||
|
return '600px'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
},
|
||||||
|
|
||||||
|
getTitleGall(table: string) {
|
||||||
|
if (fieldsTable.tableForUsers.includes(table)) {
|
||||||
|
return 'Profilo'
|
||||||
|
} else {
|
||||||
|
return fieldsTable.getTitleImgByTable(table)
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
getDirectoryGall(myrow: any, table: string, path: string) {
|
||||||
|
const userStore = useUserStore()
|
||||||
|
|
||||||
|
// console.log('getDirectoryGall', myrow)
|
||||||
|
|
||||||
|
let ris = ''
|
||||||
|
try {
|
||||||
|
let username = myrow.hasOwnProperty('username') ? myrow['username'] : ''
|
||||||
|
const userId = myrow.hasOwnProperty('userId') ? myrow['userId'] : ''
|
||||||
|
|
||||||
|
if (username === '') {
|
||||||
|
if (userId === userStore.my._id)
|
||||||
|
username = userStore.my.username
|
||||||
|
}
|
||||||
|
if (username === '') {
|
||||||
|
username = userStore.my.username
|
||||||
|
}
|
||||||
|
if (fieldsTable.tableForUsers.includes(table)) {
|
||||||
|
ris = 'profile/' + username + '/' + table
|
||||||
|
} else if (table === 'users') {
|
||||||
|
ris = 'profile/' + userStore.my.username
|
||||||
|
} else if (table === 'mygroups') {
|
||||||
|
if (myrow.hasOwnProperty('groupname'))
|
||||||
|
ris = 'mygroups/' + myrow['groupname']
|
||||||
|
} else if (table === 'circuits') {
|
||||||
|
if (myrow.hasOwnProperty('path'))
|
||||||
|
ris = 'circuits/' + myrow['path']
|
||||||
|
} else if (!!myrow && !!myrow.directory) {
|
||||||
|
ris = myrow.directory
|
||||||
|
} else if (table === 'myelems') {
|
||||||
|
ris = 'pages/' + myrow.path
|
||||||
|
} else if (table === 'listcards') {
|
||||||
|
ris = 'pages/' + myrow.path
|
||||||
|
} else if (table === 'imgcards') {
|
||||||
|
ris = 'pages/' + path
|
||||||
|
} else {
|
||||||
|
ris = table
|
||||||
|
}
|
||||||
|
} catch (e) {
|
||||||
|
console.error('err getDirectoryGall', e)
|
||||||
|
}
|
||||||
|
console.log('getDirectoryGall', ris)
|
||||||
|
return ris
|
||||||
|
},
|
||||||
|
|
||||||
|
// getLocale() {
|
||||||
// if (navigator.languages && navigator.languages.length > 0) {
|
// if (navigator.languages && navigator.languages.length > 0) {
|
||||||
// return navigator.languages[0]
|
// return navigator.languages[0]
|
||||||
// } else {
|
// } else {
|
||||||
|
|||||||
@@ -140,6 +140,8 @@ export const useGlobalStore = defineStore('GlobalStore', {
|
|||||||
},
|
},
|
||||||
provinces: [],
|
provinces: [],
|
||||||
mygroups: [],
|
mygroups: [],
|
||||||
|
selElem: {},
|
||||||
|
editOn: false,
|
||||||
}),
|
}),
|
||||||
|
|
||||||
getters: {
|
getters: {
|
||||||
@@ -908,7 +910,7 @@ export const useGlobalStore = defineStore('GlobalStore', {
|
|||||||
})
|
})
|
||||||
},
|
},
|
||||||
|
|
||||||
async loadPage(path: string) {
|
async loadPage(path: string, dove?: string) {
|
||||||
const userStore = useUserStore()
|
const userStore = useUserStore()
|
||||||
|
|
||||||
path = path.substring(1)
|
path = path.substring(1)
|
||||||
@@ -919,7 +921,7 @@ export const useGlobalStore = defineStore('GlobalStore', {
|
|||||||
return mypage
|
return mypage
|
||||||
}
|
}
|
||||||
|
|
||||||
console.log('loadPage', path)
|
// console.log(dove, '*** loadPage', path)
|
||||||
|
|
||||||
return Api.SendReq('/getpage', 'POST', { path })
|
return Api.SendReq('/getpage', 'POST', { path })
|
||||||
.then((res) => {
|
.then((res) => {
|
||||||
@@ -1786,5 +1788,12 @@ export const useGlobalStore = defineStore('GlobalStore', {
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
changeVisuDrawer(path: string, edit: boolean) {
|
||||||
|
const userStore = useUserStore()
|
||||||
|
|
||||||
|
if (userStore.isManager)
|
||||||
|
tools.setCookie('EDITPAGES', edit ? '-1' : '0')
|
||||||
|
},
|
||||||
|
|
||||||
},
|
},
|
||||||
})
|
})
|
||||||
|
|||||||
BIN
statics/upload/pages/home/_LEM9173.jpg
Normal file
|
After Width: | Height: | Size: 77 KiB |
BIN
statics/upload/pages/home/_LEM9212.jpg
Normal file
|
After Width: | Height: | Size: 9.4 MiB |
BIN
statics/upload/pages/home/sm__LEM9173.jpg
Normal file
|
After Width: | Height: | Size: 50 KiB |
BIN
upload/pages/chisiamo/DSCF2355.JPG
Normal file
|
After Width: | Height: | Size: 4.4 MiB |
BIN
upload/pages/chisiamo/DSC_0521.JPG
Normal file
|
After Width: | Height: | Size: 3.3 MiB |
BIN
upload/pages/chisiamo/IMG-20210928-WA0012.jpg
Normal file
|
After Width: | Height: | Size: 247 KiB |
BIN
upload/pages/chisiamo/IMG_0497.jpg
Normal file
|
After Width: | Height: | Size: 925 KiB |
BIN
upload/pages/chisiamo/IMG_0510.jpg
Normal file
|
After Width: | Height: | Size: 897 KiB |
BIN
upload/pages/chisiamo/IMG_0535.jpg
Normal file
|
After Width: | Height: | Size: 1.3 MiB |
BIN
upload/pages/chisiamo/_LEM9173.jpg
Normal file
|
After Width: | Height: | Size: 11 MiB |
BIN
upload/pages/chisiamo/_LEM9190.jpg
Normal file
|
After Width: | Height: | Size: 12 MiB |
BIN
upload/pages/chisiamo/_LEM9195.jpg
Normal file
|
After Width: | Height: | Size: 11 MiB |
BIN
upload/pages/chisiamo/_LEM9212.jpg
Normal file
|
After Width: | Height: | Size: 9.4 MiB |
BIN
upload/pages/chisiamo/_LEM9230.jpg
Normal file
|
After Width: | Height: | Size: 8.2 MiB |
BIN
upload/pages/home/DSCF2355.JPG
Normal file
|
After Width: | Height: | Size: 4.4 MiB |
BIN
upload/pages/home/DSC_0521.JPG
Normal file
|
After Width: | Height: | Size: 3.3 MiB |
BIN
upload/pages/home/IMG-20210928-WA0012.jpg
Normal file
|
After Width: | Height: | Size: 247 KiB |
BIN
upload/pages/home/IMG_0497.jpg
Normal file
|
After Width: | Height: | Size: 925 KiB |
BIN
upload/pages/home/IMG_0510.jpg
Normal file
|
After Width: | Height: | Size: 897 KiB |
BIN
upload/pages/home/IMG_0535.jpg
Normal file
|
After Width: | Height: | Size: 1.3 MiB |
BIN
upload/pages/home/_LEM9173.jpg
Normal file
|
After Width: | Height: | Size: 11 MiB |
BIN
upload/pages/home/_LEM9190.jpg
Normal file
|
After Width: | Height: | Size: 12 MiB |
BIN
upload/pages/home/_LEM9195.jpg
Normal file
|
After Width: | Height: | Size: 11 MiB |
BIN
upload/pages/home/_LEM9212.jpg
Normal file
|
After Width: | Height: | Size: 9.4 MiB |
BIN
upload/pages/home/_LEM9230.jpg
Normal file
|
After Width: | Height: | Size: 8.2 MiB |