
.dz-upload {
    display: block;
    background-color: red;
    height: 10px;
    width: 0%;
}
.fade-enter-active, .fade-leave-active {
      transition: opacity 2s
}
.fade-enter, .fade-leave-to /* .fade-leave-active below version 2.1.8 */ {
      opacity: 0
}


.tag-input[data-v-7f69e7de] {
  width: 100%;
  border: 1px solid #eee;
  font-size: 0.9em;
  height: 50px;
  box-sizing: border-box;
  padding: 0 10px;
}
.tag-input__tag[data-v-7f69e7de] {
  height: 30px;
  float: left;
  margin-right: 10px;
  background-color: #eee;
  margin-top: 10px;
  line-height: 30px;
  padding: 0 5px;
  border-radius: 5px;
}
.tag-input__tag > span[data-v-7f69e7de] {
  cursor: pointer;
  opacity: 0.75;
}
.tag-input__text[data-v-7f69e7de] {
  border: none;
  outline: none;
  font-size: 0.9em;
  line-height: 50px;
  background: none;
}


.map {
   position: absolute;
   overflow :hidden
}
.vue2leaflet-map {
    height: 66% !important;
    width: 66% !important;
}


.map {
   position: absolute;
   overflow :hidden
}
.vue2leaflet-map {
    height: 66% !important;
    width: 66% !important;
}


.dz-upload {
    display: block;
    background-color: red;
    height: 10px;
    width: 0%;
}
.fade-enter-active, .fade-leave-active {
      transition: opacity 2s
}
.fade-enter, .fade-leave-to /* .fade-leave-active below version 2.1.8 */ {
      opacity: 0
}


.dz-upload {
    display: block;
    background-color: red;
    height: 10px;
    width: 0%;
}
.fade-enter-active, .fade-leave-active {
      transition: opacity 2s
}
.fade-enter, .fade-leave-to {
      opacity: 0
}


.dz-upload {
    display: block;
    background-color: red;
    height: 10px;
    width: 0%;
}
.fade-enter-active, .fade-leave-active {
      transition: opacity 2s
}
.fade-enter, .fade-leave-to /* .fade-leave-active below version 2.1.8 */ {
      opacity: 0
}


.dz-upload {
    display: block;
    background-color: red;
    height: 10px;
    width: 0%;
}
.fade-enter-active, .fade-leave-active {
      transition: opacity 2s
}
.fade-enter, .fade-leave-to /* .fade-leave-active below version 2.1.8 */ {
      opacity: 0
}


.dz-upload {
    display: block;
    background-color: red;
    height: 10px;
    width: 0%;
}
.fade-enter-active, .fade-leave-active {
      transition: opacity 2s
}
.fade-enter, .fade-leave-to /* .fade-leave-active below version 2.1.8 */ {
      opacity: 0
}


/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"app.css","mappings":";AAsGA;IACA;IACA;IACA;IACA;AACA;AACA;MACA;AACA;AACA;MACA;AACA;;;ACrDA;EACA;EACA;EACA;EACA;EACA;EACA;AACA;AAEA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AACA;AAEA;EACA;EACA;AACA;AAEA;EACA;EACA;EACA;EACA;EACA;AACA;;;ACqLA;GACA;GACA;AACA;AACA;IACA;IACA;AACA;;;ACzEA;GACA;GACA;AACA;AACA;IACA;IACA;AACA;;;AC7GA;IACA;IACA;IACA;IACA;AACA;AACA;MACA;AACA;AACA;MACA;AACA;;;ACVA;IACA;IACA;IACA;IACA;AACA;AACA;MACA;AACA;AACA;MACA;AACA;;;AC3CA;IACA;IACA;IACA;IACA;AACA;AACA;MACA;AACA;AACA;MACA;AACA;;;AC+BA;IACA;IACA;IACA;IACA;AACA;AACA;MACA;AACA;AACA;MACA;AACA;;;ACtEA;IACA;IACA;IACA;IACA;AACA;AACA;MACA;AACA;AACA;MACA;AACA","sources":["webpack:///./assets/components/NewPost.vue","webpack:///./assets/components/Profile/TagInput.vue","webpack:///./assets/components/Profile/Profile.vue","webpack:///./assets/components/Profile/ShowProfile.vue","webpack:///./assets/components/Groups/NewGroup.vue","webpack:///./assets/components/Groups/Post/NewGroupPost.vue","webpack:///./assets/components/Groups/NewJoinRequest.vue","webpack:///./assets/components/Groups/GroupImage.vue","webpack:///./assets/components/Groups/NewOwner.vue"],"sourcesContent":["<template>\n        <div class=\"p-4 bg-white rounded shadow \">\n <div v-show=\"loading\" class=\"w-full max-w-xs mt-32 mb-12\">\n<div class=\"flex items-center justify-center \">\n    <div class=\"w-16 h-16 border-b-2 border-gray-900 rounded-full animate-spin\"></div>\n    </div>\n</div>\n\n        <div v-if=\"!loading\">\n                <div class=\"flex items-center justify-between\">\n\n                        <div>\n                            <div class=\"w-8\" v-if=\"authUser\">\n                                <img :src=\"authUser.avatarUri\"\n                                class=\"object-cover w-8 h-8 rounded-full\">\n                            </div>\n                        </div>\n                        <div class=\"flex flex-1 mx-4\">\n                            <input type=\"text\" v-model=\"postMessage\" name=\"body\" class=\"w-full h-8 pl-4 bg-gray-200 rounded-full\" :placeholder=\"$t('message.addapost')\">\n                            <button v-if=\"postMessage\" @click=\"dispatchPostMessage();\" class=\"px-2 py-1 ml-2 bg-gray-200 rounded-full\">{{ $t('message.dopost') }}</button>\n                        </div>\n\n                </div>\n                <div class=\"m-4\">\n                    <vue-dropzone  v-on:vdropzone-upload-progress=\"sending\" v-on:vdropzone-s3-upload-error=\"s3UploadError\"\n        v-on:vdropzone-s3-upload-success=\"s3UploadSuccess\" :awss3=\"awss3\" @vdropzone-success=\"added\" ref=\"myVueDropzone\" id=\"dropzone\" :options=\"dropzoneOptions\"></vue-dropzone>\n                </div>\n                <div>\n                    {{ $t('message.totalkb') }}: {{ totalKB }} Kilobytes\n                </div>\n            </div>\n        </div>\n</template>\n\n<script>\nimport { mapGetters } from 'vuex';\nimport vue2Dropzone from 'vue2-dropzone'\nimport 'vue2-dropzone/dist/vue2Dropzone.min.css'\nexport default {\n    components: {\n        vueDropzone: vue2Dropzone\n    },\n    data: function () {\n    return {\n      loading : false,\n      totalKB: 0,\n      dropzoneOptions: {\n          url: '/file-upload',\n          maxFiles: 1,\n          acceptedFiles: 'image/png,image/jpg,image/gif,image/jpeg,video/mp4',\n          dictDefaultMessage: this.$t('message.dropzone'),\n      },\n      awss3: {\n      signingURL: '/signature', //Where you will get signed url\n      headers: {},\n      params : {},\n      sendFileToServer :false //If you want to upload file to your server along with s3\n        }\n    }\n    },\n    methods: {\n        sending(file, totalBytes, totalBytesSent) {\n                this.totalKB = Math.floor(totalBytesSent/1000);\n        },\n        s3UploadError(e) {\n            console.log(e);\n            alert('An error occured');\n        },\n        s3UploadSuccess(filename) {\n            this.totalKB = \"All\";\n            this.$store.commit('updateCommentUploadedFilename', filename);\n        },\n        added(file, response) {\n        },\n        dispatchPostMessage() {\n            this.$refs.myVueDropzone.enable();\n            this.$refs.myVueDropzone.removeAllFiles();\n            this.loading = true;\n            this.$store.dispatch('postMessage', this);\n        }\n    },\n    name: \"NewPost\",\n    computed: {\n        postMessage: {\n            get() {\n                return this.$store.getters.postMessage;\n            },\n            set(postMessage) {\n                this.$store.commit('updateMessage', postMessage);\n            }\n        },\n\n        ...mapGetters({\n            authUser: 'authUser',\n        }),\n\n    }\n\n}\n</script>\n\n<style>\n.dz-upload {\n    display: block;\n    background-color: red;\n    height: 10px;\n    width: 0%;\n}\n .fade-enter-active, .fade-leave-active {\n      transition: opacity 2s\n   }\n   .fade-enter, .fade-leave-to /* .fade-leave-active below version 2.1.8 */ {\n      opacity: 0\n   }\n</style>","<template>\n  <div class=\"tag-input\">\n    <div v-for=\"(tag, index) in mytags\" :key=\"index\" class=\"tag-input__tag\">\n      <span @click='removeTag(index)'>x</span>\n      {{ tag }}\n    </div>\n    <input ref=\"that\"\n      type='text'\n      placeholder=\"Enter a Tag\"\n      class='tag-input__text'\n      @keydown.enter='addTag'\n      @keydown.188='addTag'\n    />\n  </div>\n</template>\n<script>\nimport axios from \"axios\";\n  export default {\n    data () {\n      return {\n      }\n    },\n    props: [\"mytags\", \"userid\", \"addurl\", \"removeurl\"],\n    methods: {\n        addTag (event) {\n        event.preventDefault()\n        var val = this.$refs[\"that\"].value;\n        if (val.length > 0) {\n            console.log(\"VAL\");\n          this.mytags.push(val)\n          event.target.value = '';\n\n          axios.post(this.addurl, { value: val })\n                            .then(res => {\n                            }).catch(error => {\n                            })\n\n        }\n\n\n\n\n        },\n        removeTag (index) {\n             axios.post(this.removeurl, { value: this.mytags[index] })\n                            .then(res => {\n                            }).catch(error => {\n                            })\n\n        this.mytags.splice(index, 1)\n        }\n    },\n    mounted() {\n      console.error(\"TAGINPUT\");\n      console.log(\"MYTAGS:\"+this.mytags);\n       // this.tags = this.mytags;\n    }\n  }\n</script>\n<style scoped>\n  .tag-input {\n    width: 100%;\n    border: 1px solid #eee;\n    font-size: 0.9em;\n    height: 50px;\n    box-sizing: border-box;\n    padding: 0 10px;\n  }\n\n  .tag-input__tag {\n    height: 30px;\n    float: left;\n    margin-right: 10px;\n    background-color: #eee;\n    margin-top: 10px;\n    line-height: 30px;\n    padding: 0 5px;\n    border-radius: 5px;\n  }\n\n  .tag-input__tag > span {\n    cursor: pointer;\n    opacity: 0.75;\n  }\n\n  .tag-input__text {\n    border: none;\n    outline: none;\n    font-size: 0.9em;\n    line-height: 50px;\n    background: none;\n  }\n</style>\n","<template>\n<div  >\n<div class=\"bg-white\">\n                        <nav class=\"flex flex-col tabs sm:flex-row\">\n                            <button data-target=\"panel-1\" @click=\"onTabClick\" :class=\"currentTab=='panel-1' ? `border-b-2 border-blue-500` : ``\" class=\"block px-6 py-4 font-medium text-gray-600 text-blue-500 tab hover:text-blue-500 focus:outline-none\">\n                                Description\n                            </button><button data-target=\"panel-2\" :class=\"currentTab=='panel-2' ? `border-b-2 border-blue-500` : ``\" @click=\"onTabClick\" class=\"block px-6 py-4 tab ext-gray-600 hover:text-blue-500 focus:outline-none\">\n                                Edit profile\n                            </button><button data-target=\"panel-3\" :class=\"currentTab=='panel-3' ? `border-b-2 border-blue-500` : ``\" @click=\"onTabClick\" class=\"block px-6 py-4 text-gray-600 tab hover:text-blue-500 focus:outline-none\">\n                                Map\n                            </button>\n                        </nav>\n                    </div>\n\n                    <div id=\"panels\">\n                        <ProfileDetails :authUser=\"authUser\" :currentTab=\"currentTab\" :profileData=\"profileData\" :showMoreFriends=\"showMoreFriends\" :tagString=\"tagString\"/>\n                        <div class=\"py-5 panel-2 tab-content\" v-if=\"currentTab=='panel-2'\">\n<form class=\"px-8 pt-6 pb-8 mb-4 bg-white rounded shadow-md\">\n    <div class=\"mb-4\">\n      <label class=\"block mb-2 text-sm font-bold text-gray-700\" for=\"tags\">\n          Tags\n      </label>\n\n      <TagInput :addurl=\"'/api/addtag/'+authUser.id\" :removeurl=\"'/api/removetag/'+authUser.id\" :mytags=\"profileData.tags\" :userid=\"authUser.id\" />\n    </div>\n      <div class=\"mb-4\">\n      <label class=\"block mb-2 text-sm font-bold text-gray-700\" for=\"tags\">\n          Website URL\n      </label>\n\n      <input @keyup=\"userinput\" v-model=\"profileData.website\" class=\"w-full px-3 py-2 leading-tight border rounded shadow appearance-none focus:outline-none focus:shadow-outline\" id=\"website\" type=\"text\" placeholder=\"http://www.supermod.net\">\n    </div>\n  </form>\n                            <div class=\"flex flex-col items-center pt-4\">\n\n\n\n                                <div class=\"p-4 bg-white rounded shadow\">\n                                        <div class=\"flex items-center justify-between\">\n\n                                                <div>\n                                                        <img v-if=\"authUser\" :src=\"authUser.avatarUri\"\n                                                        class=\"object-cover w-8 h-8 rounded-full\">\n                                                </div>\n                                        </div>\n                                    </div>\n                                    <div class=\"p-4 bg-white rounded shadow \">\n                                        <div class=\"m-4\">\n                                            <vue-dropzone @vdropzone-success=\"added\" ref=\"myVueDropzone\" id=\"dropzone\" :options=\"dropzoneOptions\"></vue-dropzone>\n                                        </div>\n                                    </div>\n\n                            </div>\n                              <div class=\"flex flex-col items-center pt-4\">\n\n\n                                <div class=\"p-4 bg-white rounded shadow\">\n                                        <div class=\"flex items-center justify-between\">\n\n                                                <div>\n                                                        <img v-if=\"authUser\" :src=\"authUser.bannerUri\"\n                                                        class=\"object-cover w-8 h-8\">\n                                                </div>\n                                        </div>\n                                    </div>\n                                    <div class=\"p-4 bg-white\">\n                                        <div class=\"m-4\">\n                                            <vue-dropzone @vdropzone-success=\"added\" ref=\"myVueBannerDropzone\" id=\"bannerDropzone\" :options=\"bannerDropzoneOptions\"></vue-dropzone>\n                                        </div>\n                                    </div>\n\n                            </div>\n                        </div>\n                        <div class=\"py-5 panel-3 tab-content\" v-if=\"currentTab=='panel-3'\">\n                           <div class=\"w-2/3 overflow-x-hidden\">\n                                {{ $t('message.markmap') }}\n                            <l-map\n                            :center=\"center\"\n                            :zoom=\"zoom\"\n                            class=\"w-1/3 overflow-x-hidden map\"\n                            ref=\"map\"\n                            @update:zoom=\"zoomUpdated\"\n                            @update:center=\"centerUpdated\" @click=\"addMarker\"\n                            >\n                                <l-marker v-for=\"marker, index in markers\" v-bind:key=\"index\" :lat-lng=\"marker\" @click=\"removeMarker(index)\"></l-marker>\n                            <l-tile-layer\n                                :url=\"url\"\n                            >\n                            </l-tile-layer>\n                            </l-map>\n                            </div>\n                            </div>\n\n                    </div>\n\n\n\n</div>\n</template>\n\n<script>\nimport ProfileStory from './ProfileStory';\nimport ProfileDetails from './ProfileDetails';\nimport axios from \"axios\";\nimport { mapGetters } from 'vuex';\nimport vue2Dropzone from 'vue2-dropzone'\nimport 'vue2-dropzone/dist/vue2Dropzone.min.css'\nimport { LMap, LTileLayer, LMarker } from 'vue2-leaflet';\nimport 'leaflet/dist/leaflet.css';\nimport \"leaflet/dist/images/marker-shadow.png\";\nimport \"leaflet/dist/images/marker-icon.png\";\nimport \"leaflet/dist/images/marker-icon-2x.png\";\nimport TagInput from \"./TagInput\";\nexport default {\n    components: {\n        vueDropzone: vue2Dropzone,\n        LMap,\n        LTileLayer,\n        LMarker,\n        ProfileStory,\n         TagInput,\n         ProfileDetails\n    },\n    mounted() {\n        axios.get('/api/profiledata/0')\n                            .then(res => {\n                                    this.profileData = res.data;\n                                    this.showMoreFriends = false;\n                                    if (this.profileData.friends.length>=6) {\n                                        this.showMoreFriends = true;\n                                        this.profileData.friends.pop();\n                                    }\n\n                            }).catch(error => {\n                                console.log(error);\n                               alert(\"A network error occured\");\n                            })\n         axios.get('/api/getmap/0')\n                            .then(res => {\n\n                                    this.markers = [\n                                        L.latLng(res.data[0], res.data[1])\n                                    ];\n                            }).catch(error => {\n                                console.log(error);\n                               alert(\"A network error occured\");\n                            })\n          delete L.Icon.Default.prototype._getIconUrl;\n        L.Icon.Default.mergeOptions({\n        iconRetinaUrl: require(\"leaflet/dist/images/marker-icon-2x.png\"),\n        iconUrl: require(\"leaflet/dist/images/marker-icon.png\"),\n        shadowUrl: require(\"leaflet/dist/images/marker-shadow.png\")\n        });\n    },\n    data: function () {\n    return {\n\n        showMoreFriends : true,\n        profileData: [],\n        currentTab : 'panel-1',\n      dropzoneOptions: {\n          url: '/profile-upload/avataruri',\n          maxFiles: 1,\n          aacceptedFiles: 'image/png,image/jpg,image/gif,image/jpeg',\n          maxFilesize: 1000000,\n          dictDefaultMessage: this.$t('message.avatarDropfiles')\n      },\n       bannerDropzoneOptions: {\n          url: '/profile-upload/banneruri',\n          maxFiles: 1,\n          aacceptedFiles: 'image/png,image/jpg,image/gif,image/jpeg',\n          maxFilesize: 1000000,\n          dictDefaultMessage: this.$t('message.bannerDropfiles')\n      },\n      url: 'https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png',\n     center: [ 40.75637123, -73.98545321 ],\n     zoom: 2,\n       markers: [\n        L.latLng(40.75637123, -73.98545321)\n      ]\n    }\n    },\n    methods: {\n        tagString() {\n            let str = '';\n            if (this.profileData.tags) {\n            for (var i = 0; i < this.profileData.tags.length; i ++) {\n                if (str.length>0) {\n                    str = str + \" \";\n                }\n                console.log(\"ADDING \"+this.profileData.tags[i]);\n                str=str+this.profileData.tags[i];\n            }\n            }\n            return str;\n        },\n        userinput(event) {\n            let website = event.target.value;\n            axios.post('/api/setinput/website', { value: website })\n                            .then(res => {\n                            }).catch(error => {\n                            })\n\n        },\n        removeMarker(index) {\n      this.markers.splice(index, 1);\n      axios.get('/api/setmap/0/0')\n                            .then(res => {\n                            }).catch(error => {\n                               alert(\"A network error occured\");\n                            })\n    },\n    addMarker(event) {\n      this.markers=[];\n      this.markers.push(event.latlng);\n      axios.get('/api/setmap/'+event.latlng.lat+\"/\"+event.latlng.lng)\n                            .then(res => {\n\n                            }).catch(error => {\n                               alert(\"A network error occured\");\n                            })\n    },\n        added(file, response) {\n            let responseData = response.status;\n\n            if (responseData == 'OK') {\n            this.$store.dispatch('fetchAuthUser');\n            } else if (responseData == 'error') {\n                alert('A file upload error occured, image size limit is 1MB');\n                this.$refs.myVueDropzone.removeAllFiles();\n            }\n        },\n        dispatchPostMessage() {\n            this.$refs.myVueDropzone.enable();\n            this.$refs.myVueDropzone.removeAllFiles();\n            this.$store.dispatch('postMessage');\n        },\n        zoomUpdated (zoom) {\n            this.zoom = zoom;\n            console.log(this.markers)\n        },\n        centerUpdated (center) {\n            this.center = center;\n        },\n        onTabClick(event) {\n\n        let classString = event.target.getAttribute('data-target');\n        this.currentTab = classString;\n        console.log(this.currentTab);\n        },\n    },\n    name: \"Profile\",\n    computed: {\n        postMessage: {\n            get() {\n                return this.$store.getters.postMessage;\n            },\n            set(postMessage) {\n                this.$store.commit('updateMessage', postMessage);\n            }\n        },\n\n        ...mapGetters({\n            authUser: 'authUser',\n        }),\n\n    }\n\n}\n</script>\n\n<style>\n .map {\n   position: absolute;\n   overflow :hidden\n }\n .vue2leaflet-map {\n    height: 66% !important;\n    width: 66% !important;\n}\n</style>\n","<template>\n<div  >\n<div class=\"bg-white\">\n                        <nav class=\"flex flex-col tabs sm:flex-row\">\n                            <button data-target=\"panel-1\" @click=\"onTabClick\" :class=\"currentTab=='panel-1' ? `border-b-2 border-blue-500` : ``\" class=\"block px-6 py-4 font-medium text-gray-600 text-blue-500 tab hover:text-blue-500 focus:outline-none\">\n                                Description\n                            </button>\n                            <button v-if=\"profileData.mapChanged == 1\" data-target=\"panel-2\" :class=\"currentTab=='panel-2' ? `border-b-2 border-blue-500` : ``\" @click=\"onTabClick\" class=\"block px-6 py-4 text-gray-600 tab hover:text-blue-500 focus:outline-none\" >\n                                Map\n                            </button>\n                        </nav>\n                    </div>\n                    <div id=\"panels\">\n\n                        <ProfileDetails :authUser=\"authUser\" :currentTab=\"currentTab\" :profileData=\"profileData\" :showMoreFriends=\"showMoreFriends\" :tagString=\"tagString\"/>\n                        <div class=\"py-5 panel-3 tab-content\" v-if=\"currentTab=='panel-2'\">\n                           <div class=\"w-2/3 overflow-x-hidden\">\n                            <l-map\n                            :center=\"center\"\n                            :zoom=\"zoom\"\n                            class=\"w-1/3 overflow-x-hidden map\"\n                            ref=\"map\"\n                            @update:zoom=\"zoomUpdated\"\n                            @update:center=\"centerUpdated\"\n                            >\n                                <l-marker v-for=\"marker, index in markers\" v-bind:key=\"index\" :lat-lng=\"marker\"></l-marker>\n                            <l-tile-layer\n                                :url=\"url\"\n                            >\n                            </l-tile-layer>\n                            </l-map>\n                            </div>\n                            </div>\n\n                    </div>\n\n\n\n</div>\n</template>\n\n<script>\nimport ProfileDetails from './ProfileDetails';\nimport axios from \"axios\";\nimport { mapGetters } from 'vuex';\nimport vue2Dropzone from 'vue2-dropzone'\nimport 'vue2-dropzone/dist/vue2Dropzone.min.css'\nimport { LMap, LTileLayer, LMarker } from 'vue2-leaflet';\nimport 'leaflet/dist/leaflet.css';\nimport \"leaflet/dist/images/marker-shadow.png\";\nimport \"leaflet/dist/images/marker-icon.png\";\nimport \"leaflet/dist/images/marker-icon-2x.png\";\nimport TagInput from \"./TagInput\";\nexport default {\n    components: {\n        vueDropzone: vue2Dropzone,\n        LMap,\n        LTileLayer,\n        LMarker,\n         TagInput,\n         ProfileDetails\n    },\n    props: [\"id\"],\n    mounted() {\n        delete L.Icon.Default.prototype._getIconUrl;\n        L.Icon.Default.mergeOptions({\n        iconRetinaUrl: require(\"leaflet/dist/images/marker-icon-2x.png\"),\n        iconUrl: require(\"leaflet/dist/images/marker-icon.png\"),\n        shadowUrl: require(\"leaflet/dist/images/marker-shadow.png\")\n        });\n        axios.get('/api/profiledata/'+this.id)\n                            .then(res => {\n                                    this.profileData = res.data;\n                                    this.showMoreFriends = false;\n                                    if (this.profileData.friends.length>=6) {\n                                        this.showMoreFriends = true;\n                                        this.profileData.friends.pop();\n                                    }\n\n                            }).catch(error => {\n                                console.log(error);\n                               alert(\"A network error occured\");\n                            })\n         axios.get('/api/getmap/'+this.id)\n                            .then(res => {\n\n                                    this.markers = [\n                                        L.latLng(res.data[0], res.data[1])\n                                    ];\n                            }).catch(error => {\n                                console.log(error);\n                               alert(\"A network error occured\");\n                            })\n\n    },\n    data: function () {\n    return {\n\n        showMoreFriends : false,\n        profileData: [],\n        currentTab : 'panel-1',\n      dropzoneOptions: {\n          url: '/profile-upload',\n          maxFiles: 1,\n          aacceptedFiles: 'image/png,image/jpg,image/gif,image/jpeg',\n          maxFilesize: 1000000,\n          dictDefaultMessage: this.$t('message.avatarDropfiles')\n      },\n      url: 'https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png',\n     center: [ 40.75637123, -73.98545321 ],\n     zoom: 2,\n       markers: [\n        L.latLng(40.75637123, -73.98545321)\n      ]\n    }\n    },\n    methods: {\n        tagString() {\n            let str = '';\n            if (this.profileData.tags) {\n            for (var i = 0; i < this.profileData.tags.length; i ++) {\n                if (str.length>0) {\n                    str = str + \" \";\n                }\n                console.log(\"ADDING \"+this.profileData.tags[i]);\n                str=str+this.profileData.tags[i];\n            }\n            }\n            return str;\n        },\n        userinput(event) {\n            let website = event.target.value;\n            axios.post('/api/setinput/website', { value: website })\n                            .then(res => {\n                            }).catch(error => {\n                            })\n\n        },\n        removeMarker(index) {\n      this.markers.splice(index, 1);\n      axios.get('/api/setmap/0/0')\n                            .then(res => {\n                            }).catch(error => {\n                               alert(\"A network error occured\");\n                            })\n    },\n    addMarker(event) {\n      this.markers=[];\n      this.markers.push(event.latlng);\n      axios.get('/api/setmap/'+event.latlng.lat+\"/\"+event.latlng.lng)\n                            .then(res => {\n\n                            }).catch(error => {\n                               alert(\"A network error occured\");\n                            })\n    },\n        added(file, response) {\n            let responseData = response.status;\n\n            if (responseData == 'OK') {\n            this.$store.dispatch('fetchAuthUser');\n            } else if (responseData == 'error') {\n                alert('A file upload error occured, image size limit is 1MB');\n                this.$refs.myVueDropzone.removeAllFiles();\n            }\n        },\n        dispatchPostMessage() {\n            this.$refs.myVueDropzone.enable();\n            this.$refs.myVueDropzone.removeAllFiles();\n            this.$store.dispatch('postMessage');\n        },\n        zoomUpdated (zoom) {\n            this.zoom = zoom;\n            console.log(this.markers)\n        },\n        centerUpdated (center) {\n            this.center = center;\n        },\n        onTabClick(event) {\n\n        let classString = event.target.getAttribute('data-target');\n        this.currentTab = classString;\n        console.log(this.currentTab);\n        },\n    },\n    name: \"Profile\",\n    computed: {\n        postMessage: {\n            get() {\n                return this.$store.getters.postMessage;\n            },\n            set(postMessage) {\n                this.$store.commit('updateMessage', postMessage);\n            }\n        },\n\n        ...mapGetters({\n            authUser: 'authUser',\n        }),\n\n    }\n\n}\n</script>\n\n<style>\n .map {\n   position: absolute;\n   overflow :hidden\n }\n .vue2leaflet-map {\n    height: 66% !important;\n    width: 66% !important;\n}\n</style>\n","<template>\n\n        <div class=\"p-4 bg-white rounded shadow \">\n\n <div v-show=\"loading\" class=\"w-full max-w-xs mt-32 mb-12\">\n<div class=\"flex items-center justify-center \">\n    <div class=\"w-16 h-16 border-b-2 border-gray-900 rounded-full animate-spin\"></div>\n    </div>\n</div>\n\n        <div v-if=\"!loading\">\n                <div class=\"flex items-center justify-between\">\n\n                        <div>\n                            <div class=\"w-8\" v-if=\"authUser\">\n                                <img :src=\"authUser.avatarUri\"\n                                class=\"object-cover w-8 h-8 rounded-full\">\n                            </div>\n                        </div>\n                        <div class=\"flex flex-1 mx-4\">\n                            <input type=\"text\" v-model=\"postMessage\" name=\"body\" class=\"w-full h-8 pl-4 bg-gray-200 rounded-full\" :placeholder=\"$t('message.addagroup')\">\n                            <button v-if=\"postMessage\" @click=\"dispatchPostMessage();\" class=\"px-2 py-1 ml-2 bg-gray-200 rounded-full\">{{ $t('message.docreate') }}</button>\n                        </div>\n\n                </div>\n                <div class=\"m-4\">\n                    <vue-dropzone  v-on:vdropzone-upload-progress=\"sending\" v-on:vdropzone-s3-upload-error=\"s3UploadError\"\n        v-on:vdropzone-s3-upload-success=\"s3UploadSuccess\" :awss3=\"awss3\" @vdropzone-success=\"added\" ref=\"myVueDropzone\" id=\"dropzone\" :options=\"dropzoneOptions\"></vue-dropzone>\n                </div>\n                <div>\n                    {{ $t('message.totalkb') }}: {{ totalKB }} Kilobytes\n                </div>\n            </div>\n        </div>\n</template>\n\n<script>\nimport { mapGetters } from 'vuex';\nimport vue2Dropzone from 'vue2-dropzone'\nimport 'vue2-dropzone/dist/vue2Dropzone.min.css'\nexport default {\n    components: {\n        vueDropzone: vue2Dropzone\n    },\n    data: function () {\n    return {\n      loading : false,\n      totalKB: 0,\n      dropzoneOptions: {\n          url: '/file-upload',\n          maxFiles: 1,\n          acceptedFiles: 'image/png,image/jpg,image/gif,image/jpeg,video/mp4',\n          dictDefaultMessage: this.$t('message.dropzone'),\n      },\n      awss3: {\n      signingURL: '/signature', //Where you will get signed url\n      headers: {},\n      params : {},\n      sendFileToServer :false //If you want to upload file to your server along with s3\n        }\n    }\n    },\n    methods: {\n        sending(file, totalBytes, totalBytesSent) {\n                this.totalKB = Math.floor(totalBytesSent/1000);\n        },\n        s3UploadError(e) {\n            console.log(e);\n            alert('An error occured');\n        },\n        s3UploadSuccess(filename) {\n            this.totalKB = \"All\";\n            this.$store.commit('updateGroupUploadedFilename', filename);\n        },\n        added(file, response) {\n        },\n        dispatchPostMessage() {\n            this.$refs.myVueDropzone.enable();\n            this.$refs.myVueDropzone.removeAllFiles();\n            this.loading = true;\n            this.$store.dispatch('postGroup', this);\n        }\n    },\n    name: \"NewGroup\",\n    computed: {\n        postMessage: {\n            get() {\n                return this.$store.getters.postMessage;\n            },\n            set(postMessage) {\n                this.$store.commit('updateMessage', postMessage);\n            }\n        },\n\n        ...mapGetters({\n            authUser: 'authUser',\n        }),\n\n    }\n\n}\n</script>\n\n<style>\n.dz-upload {\n    display: block;\n    background-color: red;\n    height: 10px;\n    width: 0%;\n}\n .fade-enter-active, .fade-leave-active {\n      transition: opacity 2s\n   }\n   .fade-enter, .fade-leave-to /* .fade-leave-active below version 2.1.8 */ {\n      opacity: 0\n   }\n</style>","<template>\n        <div class=\"p-4 mt-4 bg-white rounded shadow \">\n <div v-show=\"loading\" class=\"w-full max-w-xs mt-32 mb-12\">\n<div class=\"flex items-center justify-center \">\n    <div class=\"w-16 h-16 border-b-2 border-gray-900 rounded-full animate-spin\"></div>\n    </div>\n</div>\n\n        <div v-if=\"!loading\">\n                <div class=\"flex items-center justify-between\">\n                        <div>\n                            <div class=\"w-8\" v-if=\"authUser\">\n                                <router-link :to=\"'/'+authUser.userName\">\n                                <img :src=\"authUser.avatarUri\" class=\"object-cover w-8 h-8 rounded-full\">\n                                </router-link>\n\n                            </div>\n                        </div>\n                        <div class=\"flex flex-1 mx-4\">\n                            <input type=\"text\" v-model=\"postGroupMessage\" name=\"body\" class=\"w-full h-8 pl-4 bg-gray-200 rounded-full\" :placeholder=\"$t('message.addapost')\">\n                            <button v-if=\"postGroupMessage\" @click=\"dispatchPostGroupMessage();\" class=\"px-2 py-1 ml-2 bg-gray-200 rounded-full\">{{ $t('message.dopost') }}</button>\n                        </div>\n\n                </div>\n                <div class=\"m-4\">\n                    <vue-dropzone  v-on:vdropzone-upload-progress=\"sending\" v-on:vdropzone-s3-upload-error=\"s3UploadError\"\n        v-on:vdropzone-s3-upload-success=\"s3UploadSuccess\" :awss3=\"awss3\" @vdropzone-success=\"added\" ref=\"myVueDropzone\" id=\"dropzone\" :options=\"dropzoneOptions\"></vue-dropzone>\n                </div>\n                <div>\n                    {{ $t('message.totalkb') }}: {{ totalKB }} Kilobytes\n                </div>\n            </div>\n        </div>\n</template>\n\n<script>\nimport { mapGetters } from 'vuex';\nimport vue2Dropzone from 'vue2-dropzone'\nimport 'vue2-dropzone/dist/vue2Dropzone.min.css'\nexport default {\n    components: {\n        vueDropzone: vue2Dropzone\n    },\n    data: function () {\n    return {\n      loading : false,\n      totalKB: 0,\n      dropzoneOptions: {\n          url: '/file-upload',\n          maxFiles: 1,\n          acceptedFiles: 'image/png,image/jpg,image/gif,image/jpeg,video/mp4',\n          dictDefaultMessage: this.$t('message.dropzone'),\n      },\n      awss3: {\n      signingURL: '/signature', //Where you will get signed url\n      headers: {},\n      params : {},\n      sendFileToServer :false //If you want to upload file to your server along with s3\n        }\n    }\n    },\n    methods: {\n        sending(file, totalBytes, totalBytesSent) {\n                this.totalKB = Math.floor(totalBytesSent/1000);\n        },\n        s3UploadError(e) {\n            console.log(e);\n            alert('An error occured');\n        },\n        s3UploadSuccess(filename) {\n            this.totalKB = \"All\";\n            this.$store.commit('updateGroupCommentUploadedFilename', filename);\n        },\n        added(file, response) {\n        },\n        dispatchPostGroupMessage() {\n            this.$refs.myVueDropzone.enable();\n            this.$refs.myVueDropzone.removeAllFiles();\n            this.loading = true;\n            this.$store.dispatch('postGroupMessage', { that: this, page: this.$route.params.id });\n        }\n    },\n    name: \"NewGroupPost\",\n    computed: {\n        postGroupMessage: {\n            get() {\n                console.log(\"GETTING :\"+this.$store.getters.postGroupMessage);\n                return this.$store.getters.postGroupMessage;\n            },\n            set(postGroupMessage) {\n                console.log(\"SETTINGG:\"+postGroupMessage);\n                this.$store.commit('updateGroupMessage', postGroupMessage);\n            }\n        },\n\n        ...mapGetters({\n            authUser: 'authUser',\n        }),\n\n    }\n\n}\n</script>\n\n<style>\n.dz-upload {\n    display: block;\n    background-color: red;\n    height: 10px;\n    width: 0%;\n}\n .fade-enter-active, .fade-leave-active {\n      transition: opacity 2s\n   }\n   .fade-enter, .fade-leave-to {\n      opacity: 0\n   }\n</style>","<template>\n\n        <div class=\"p-4 mt-4 bg-white rounded shadow\">\n\n <div v-show=\"loading\" class=\"w-full max-w-xs mt-32 mb-12\">\n<div class=\"flex items-center justify-center \">\n    <div class=\"w-16 h-16 border-b-2 border-gray-900 rounded-full animate-spin\"></div>\n    </div>\n</div>\n\n        <div v-if=\"!loading\">\n            <div v-if=\"!showJoined\">\n                <div>\n                    Become a member - provide a reason\n                </div>\n                <div class=\"flex items-center justify-between\">\n\n\n                        <div class=\"w-8 mt-4\" v-if=\"authUser\">\n                            <img :src=\"authUser.avatarUri\"\n                            class=\"object-cover w-8 h-8 rounded-full\">\n                        </div>\n\n                        <div class=\"flex flex-1 mx-4\">\n\n                            <textarea v-model=\"postMessage\" name=\"body\" class=\"w-full pl-4 bg-gray-200 h-36\" :placeholder=\"$t('message.reason')\" />\n                            <button v-if=\"postMessage\" @click=\"dispatchJoinRequest();\" class=\"h-8 px-2 py-1 ml-2 bg-gray-200 rounded-full\">{{ $t('message.send') }}</button>\n                        </div>\n\n                </div>\n            </div>\n            </div>\n            <div v-if=\"showJoined\">\n                <div >\n                    {{ $t('message.joinsuccess') }}\n                </div>\n        </div>\n        </div>\n\n</template>\n\n<script>\nimport { mapGetters } from 'vuex';\nexport default {\n    components: {\n    },\n    data: function () {\n    return {\n        postMessage : '',\n      loading : false,\n      showJoined : false\n    }\n    },\n    methods: {\n\n        dispatchJoinRequest() {\n            this.$store.dispatch('postGroupJoinRequest', { postMessage: this.postMessage, groupid: this.$route.params.id, that : this });\n        }\n    },\n    name: \"NewJoinRequest\",\n    computed: {\n\n\n        ...mapGetters({\n            authUser: 'authUser',\n        }),\n\n    }\n\n}\n</script>\n\n<style>\n.dz-upload {\n    display: block;\n    background-color: red;\n    height: 10px;\n    width: 0%;\n}\n .fade-enter-active, .fade-leave-active {\n      transition: opacity 2s\n   }\n   .fade-enter, .fade-leave-to /* .fade-leave-active below version 2.1.8 */ {\n      opacity: 0\n   }\n</style>","<template>\n\n        <div class=\"p-4 bg-white rounded shadow \">\n\n                        <div class=\"mx-4 mb-4\">\n                          {{ $t('message.currentimage') }}\n                        </div>\n                        <div>\n                            <div v-if=\"photoType=='mp4'\">\n                    <vue-plyr >\n                        <video\n                            controls\n                            crossorigin\n                            playsinline\n                        >\n                            <source\n                            :src=\"photo\"\n                            type=\"video/mp4\"\n                            />\n                        </video>\n                        </vue-plyr>\n                </div>\n                <div v-else>\n                    <img :src=\"photo\" class=\"w-full\">\n                </div>\n                        </div>\n                        <div class=\"mx-4 mt-4\">\n                           {{ $t('message.newimage') }}\n                        </div>\n\n\n                <div class=\"m-4\">\n                    <vue-dropzone  v-on:vdropzone-upload-progress=\"sending\" v-on:vdropzone-s3-upload-error=\"s3UploadError\"\n        v-on:vdropzone-s3-upload-success=\"s3UploadSuccess\" :awss3=\"awss3\" @vdropzone-success=\"added\" ref=\"myVueDropzone\" id=\"dropzone\" :options=\"dropzoneOptions\"></vue-dropzone>\n                </div>\n                <div>\n                    {{ $t('message.totalkb') }}: {{ totalKB }} Kilobytes\n                </div>\n\n        </div>\n</template>\n\n<script>\nimport axios from \"axios\"\nimport { mapGetters } from 'vuex';\nimport vue2Dropzone from 'vue2-dropzone'\nimport 'vue2-dropzone/dist/vue2Dropzone.min.css'\nexport default {\n    components: {\n        vueDropzone: vue2Dropzone\n    },\n    props: [\"groupDetail\"],\n    data: function () {\n    return {\n      photoType : '',\n      photo : '',\n      totalKB: 0,\n      dropzoneOptions: {\n          url: '/file-upload',\n          maxFiles: 1,\n          acceptedFiles: 'image/png,image/jpg,image/gif,image/jpeg,video/mp4',\n          dictDefaultMessage: this.$t('message.dropzone'),\n      },\n      awss3: {\n      signingURL: '/signature', //Where you will get signed url\n      headers: {},\n      params : {},\n      sendFileToServer :false //If you want to upload file to your server along with s3\n        }\n    }\n    },\n    mounted() {\n        console.log(this.groupDetail);\n        this.photoType = this.groupDetail.photoType;\n        this.photo = this.groupDetail.photo;\n    },\n    methods: {\n        sending(file, totalBytes, totalBytesSent) {\n                this.totalKB = Math.floor(totalBytesSent/1000);\n        },\n        s3UploadError(e) {\n            console.log(e);\n            alert('An error occured');\n        },\n        s3UploadSuccess(filename) {\n            this.totalKB = \"All\";\n             axios.post('/api/postgroupimage/'+this.$route.params.id, { uploadedFilename : filename })\n            .then(res => {\n                if (res.data.status=='error') {\n                alert(res.data.details);\n                } else {\n                        this.photo = res.data.photo;\n                        this.photoType = res.data.photoType;\n                }\n\n            }).catch(error => {\n               console.error(error);\n            })\n        },\n        added(file, response) {\n        },\n    },\n    name: \"GroupImage\",\n    computed: {\n\n        ...mapGetters({\n            authUser: 'authUser',\n        }),\n\n    }\n\n}\n</script>\n\n<style>\n.dz-upload {\n    display: block;\n    background-color: red;\n    height: 10px;\n    width: 0%;\n}\n .fade-enter-active, .fade-leave-active {\n      transition: opacity 2s\n   }\n   .fade-enter, .fade-leave-to /* .fade-leave-active below version 2.1.8 */ {\n      opacity: 0\n   }\n</style>","<template>\n\n        <div class=\"p-4 mt-4 bg-white rounded shadow \">\n\n <div v-show=\"loading\" class=\"w-full max-w-xs mt-32 mb-12\">\n<div class=\"flex items-center justify-center \">\n    <div class=\"w-16 h-16 border-b-2 border-gray-900 rounded-full animate-spin\"></div>\n    </div>\n</div>\n\n        <div v-if=\"!loading\">\n                <div>\n                    <p>{{ $t('message.youareowner') }}</p>\n                    <p v-if=\"groupDetails.numberOfJoinRequests > 0\">{{ $t('message.youhave') }} {{ groupDetails.numberOfJoinRequests }} {{ $t('message.joinrequests') }}.</p>\n                    <p v-if=\"groupDetails.numberOfJoinRequests > 0\" class=\"text-blue-700\">\n                        <router-link to=\"/joinrequests\">\n                        {{ $t('message.clickhere') }}\n                        </router-link>\n                    </p>\n                </div>\n            </div>\n        </div>\n</template>\n\n<script>\nimport { mapGetters } from 'vuex';\nexport default {\n    components: {\n    },\n    data: function () {\n    return {\n        postMessage : '',\n      loading : false,\n    }\n    },\n    methods: {\n\n        dispatchJoinRequest() {\n            this.$store.dispatch('postGroupJoinRequest', { postMessage: this.postMessage, groupid: this.$route.params.id });\n        }\n    },\n    name: \"NewJoinRequest\",\n    computed: {\n\n\n        ...mapGetters({\n            authUser: 'authUser',\n            groupDetails: 'groupDetails',\n        }),\n\n    }\n\n}\n</script>\n\n<style>\n.dz-upload {\n    display: block;\n    background-color: red;\n    height: 10px;\n    width: 0%;\n}\n .fade-enter-active, .fade-leave-active {\n      transition: opacity 2s\n   }\n   .fade-enter, .fade-leave-to /* .fade-leave-active below version 2.1.8 */ {\n      opacity: 0\n   }\n</style>"],"names":[],"sourceRoot":""}*/