Software

How to implement multiselect in Vue

Vuejs - Tue, 2017-08-15 06:04

I am trying to mimic the spreadsheet feature where I can select multiple table cells by pressing shift + mouseover, and I am having some trouble getting it to select the nearby cells that fall within the start and end range of the selection. So for example, with a 3x3 grid, cell 0,0 is the start cell, when I mouseover 0,1, and 1,1 1,0 should also get selected as it falls within the range. Here is the logic I have so far, but it only selects the cells as the mouse passes over (non of the adjacent cells get selected).

Here is my code:

selectCell (row, col) { this.coors.push({x: row, y: col}) let len = this.coors.length - 1 this.start = {x: this.coors[0].x, y: this.coors[0].y} this.end = {x: this.coors[len].x, y: this.coors[len].y} this.grid[row].splice(col, 1, 2) this.iterateOverGrid(2) }, iterateOverGrid (col) { for (let i = this.start.x; i <= this.end.x; i++) { this.grid[i].splice(this.end.y, 1, col) for (let j = this.start.y; j <= this.end.y; j++) { this.grid[i].splice(this.end.y, 1, col) } } },

start holds the x and y position of the first cell selected; end holds the x and y position of the last cell selected. The idea is to iterate over each row and column in the grid (which I am attempting to do in my iterateOverGrid() method) and then assign a value of 2 to each cell that falls within the start end parameter. How exactly can I achieve this?

Categories: Software

Why Data gets leaked into sibling Instance of Component when Removed vue 2

Vuejs - Tue, 2017-08-15 05:34

I am building with following scenario. Parent creates multi instances of a child component. Each child holds its data via input field. Child can ask to be removed and parent removes that instance. so far so good. So now is the problem, as soon as that instance is removed, its data gets passed/leaked to next sibling instance and if that instance is holding data, it gets moved to other next-to-it instance. I have reproduced it on [fiddle][1]

or see below

Vue.component('child', { props:['data'], template: ` <div> index# {{data}}: {{messages}} <input type="text" v-model="text" @keypress.enter="addMessage"> <button @click="addMessage">Add</button> <button @click="$emit('delete-me')">Delete</button> </div>`, data() { return { messages:[], text: '' } }, methods: { addMessage() { this.messages.push(this.text) this.text = '' } } }) Vue.component('parent', { template: ` <div> Keep Adding new Instances <button @click="newChild">New</button> <hr /> <child v-for="(child, index) in children" key="index" v-on:delete-me="deleteThisRow(index)" keys="index" :data="child" ></child> </div>`, data() { return { children:[] } }, methods: { newChild() { this.children.push(this.children.length) }, deleteThisRow(index) { this.children.splice(index, 1); } } }) new Vue({ el: '#app', template: ` <div> <parent /> </div> `, methods: { } }) <script src="https://cdnjs.cloudflare.com/ajax/libs/vue/2.3.3/vue.min.js"></script> <div id="app"></div>

Categories: Software

How to split the dev-server.js file in vue to several separated files?

Vuejs - Tue, 2017-08-15 05:07

I am using vue.js to compose a app, and I mocked a login api of localhost in dev-server.js, now I want to separate the code about login api into a independent file, what should I do? Besides there are some code about CORS, here is the code:

var app = express() var bodyParser = require('body-parser') var multer = require('multer') var upload = multer() app.use(bodyParser.json()) app.use(bodyParser.urlencoded({extended: true})) // CORS var allowCrossDomain = function (req, res, next) { res.header('Access-Control-Allow-Origin', 'http://localhost:8080') res.header('Access-Control-Allow-Methods', 'GET, POST, PUT, DELETE') res.header('Access-Control-Allow-Headers', 'Content-Type, X-Token') res.header('Access-Control-Allow-Credentials', 'true') next() } app.use(allowCrossDomain) // mock localhost api var apiRoutes = express.Router() // login api; const userAccountList = ['100000', '100001', '100002', '100003'] apiRoutes.post('/user/login', upload.array(), function (req, res) { if (userAccountList.indexOf(req.body.account) < 0){ return res.json({ code: 50000, msg: 'the account or the password is not correct, please try again' }); } } app.use('/api', apiRoutes);
Categories: Software

How to integrate Vue.Draggable into my components

Vuejs - Tue, 2017-08-15 04:08

I'm trying to integrate vue.draggable into my project https://github.com/SortableJS/Vue.Draggable

I'm a little confused as to how to integrate my existing project with Vue.draggable. I want every element that is created in the v-for loop to be draggable. I'm used to using jQuery UI to achieve this, but obviously I want a vue-centric approach.

What is the best way to do this?

var height = $(document).height(); var width = $(document).width(); $(function() { Vue.component('sidebar', { data: () => { return { people: [] } }, template: ` <div id="sidebar"> <div v-for="person in people" :class="[{'checked-in': isCheckedIn(person)}, 'person']" :id="person.id"> {{person.first_name + ' ' + person.last_name}} </div> </div> `, methods: { isCheckedIn(person) { return person.reg_scan == null ? true : false; }, loadPeople() { $.ajax({ method: 'POST', dataType: 'json', url: base_url + 'users/getParticipants/' + event_id }).done(data => { this.people = data; }); } }, mounted() { this.loadPeople(); setInterval(() => { console.log("Getting People"); this.loadPeople(); }, 10000); } }); Vue.component('tables', { data: () => { return { tables: [] } }, template: ` <div id="tables"> <div class='table' v-for="table in tables" :style="computeOffsets(table)"> {{table.name}} </div> </div> `, methods: { loadTables() { $.ajax({ method: 'POST', dataType: 'json', url: base_url + 'tables/getTables/' + event_id }).done(data => { this.tables = data; }); }, computeOffsets(table) { return { top: (table.position_x * width) + 'px', left: (table.position_y * height) + 'px' } } }, mounted() { this.loadTables(); setInterval(() => { console.log("Getting Tables"); this.loadTables(); }, 10000); } }); var app = new Vue({ el: '#main' }); }); .table { position: absolute; } #sidebar { width: 10%; float: left; height: 500px; overflow-y: scroll; } .checked-in { background-color: lightgreen; } <head> <script src="//cdnjs.cloudflare.com/ajax/libs/vue/2.3.4/vue.min.js"></script> <script src="//cdnjs.cloudflare.com/ajax/libs/Sortable/1.6.0/Sortable.min.js"></script> <script src="//cdnjs.cloudflare.com/ajax/libs/Vue.Draggable/2.14.1/vuedraggable.min.js"></script> </head> <div id="main"> <sidebar></sidebar> <tables></tables> </div>

Categories: Software

Laravel with Core UI Vue JS

Vuejs - Tue, 2017-08-15 03:49

I am trying to use Core UI Vue with Laravel 5.4/mix. I've tried merging the two projects together but with no luck. Does anybody know how to merge the two together? They both use npm, I'm new to that as well so I'm pretty vague.

Thanks in advance, any help is much appreciated.

Categories: Software

VueJS: how can i use two computed properties inside one v-for?

Vuejs - Tue, 2017-08-15 02:55

I have this computed property:

computed: { filteredCars: function() { var self = this return self.carros.filter(function(carro) { return carro.nome.indexOf(self.busca) !== -1 }) }, },

and i'm using v-for like this:

<tr v-for="carro in filteredCars"> <td>{{carro.nome}}</td> <td>{{carro.marca}}</td> <td>{{carro.categoria}}</td> <td>{{carro.motor}}</td> <td>{{carro.cambio}}</td> <td>{{carro.preco}}</td> </tr>

but I need to create another computed property to limit my data quantity, how i call it inside the same v-for?

Categories: Software

How to bind classes in vuejs?

Vuejs - Tue, 2017-08-15 01:08

I try to bind more classes with v-bind:class i have radio buttons that i want to give some classes from bootstrap when is active like so. I know i don't put the classes succesful.

<div id="app"> <div class="btn-group" data-toggle="buttons"> <label :class="{'btn', 'btn-warning', 'active: radio === 1'}"> <input v-model="removelines" type="radio" autocomplete="off" v-bind:value="yes" v-on:click="radio = 1"> yes </label> <label :class="{'btn', 'btn-warning', 'active: radio === 2'}"> <input v-model="removelines" type="radio" v-bind:value="no" v-on:click="radio = 2"> no </label> </div> </div>

and

new Vue{( el:'#app', data:{ radio: 1 } )};
Categories: Software

Change CSS asynchronously

Vuejs - Tue, 2017-08-15 00:12

Is there a way to change css properties asynchronously?

I have full access to node, vue, and it's to sit in a chrome browser, and the text I need to update the css to is various pages long, so the browser slows to a crawl while the css is applying.

fontSize (newSize) { document.getElementById('text').style.fontSize = `${newSize}px` }

I need to modify it to update the page better, and I'm not sure how to go about it. I was looking at the async module, but it's awfully dense and I'm not 100% sure it offers what I need.

Categories: Software

vue router's router-link in google maps infowindow

Vuejs - Mon, 2017-08-14 23:45

I've got this working fine, except that I've would like instead of <a> tag to use <router-link> tag because of <a> tag unlike <router-link> (which intercepts click event and don't reload the page) reloads a page.

const contentString = ` <div class="popup"> <a href="/places/${place._id}"> <img src="..." /> <h5>${place.name}</h5> <p>${place.gmap.address}</p> </a> </div>` const infoWindow = new google.maps.InfoWindow() infoWindow.setContent(contentString)

If I replace <a> tag for <router-link> it doesn't render to <a> tag as it would if that <router-link> was in vuejs template.

Categories: Software

Vue.js throwing inexplicable syntax error for Blackberry browser 10.3

Vuejs - Mon, 2017-08-14 23:28

I'm using Vue.js to build a site and I'm getting the following error in Blackberry Browser 10.3:

SyntaxError: Unexpected token '(' app.a3c4ee08427b9dd5e351.js:268

And when I view the line that's referenced in the error in the compiled app.a3c4ee08427b9dd5e351.js file I see the following:

/* harmony default export */ __webpack_exports__["default"] = ({ name: 'app-header', components: {}, data: function () { return {}; }, mounted() {}, <-- THIS IS LINE 268 REFERENCED IN THE ERROR methods: {} });

I'm using the "Single-File Template" method and this is what the above block looks like uncompiled in my source:

<script> export default { name: 'app-header', components : {}, data : function() { return {} }, mounted() { $(document).ready(function() { $('.nav-link').on('click', function() { $(document).stop().animate({ scrollTop : 0 }, 444); }); }); } } </script>

So the block throwing the error is missing the contents of the mounted() function. BUT, there's a second block further down in the compiled file that does have the contents of the mounted() function intact for the app-header component:

/* harmony default export */ __webpack_exports__["default"] = ({ name: 'app-header', components: {}, data: function () { return {}; }, mounted() { $(document).ready(function () { $('.nav-link').on('click', function () { $(document).stop().animate({ scrollTop: 0 }, 444); }); }); } });

The error itself seems to be saying that I've got an errant ( somewhere, but I've combed over it 1000 times and can't seem to find where this is happening.

Also, this works perfectly well in all other browsers.

Anyone have any idea what could be causing this for BB Browser 10.3?

Note: The client owns a Blackberry, which is why we're targeting a device that only 5 or 6 people on the planet actually use.

Categories: Software

Vue Js not rendering the computed property

Vuejs - Mon, 2017-08-14 23:15

I am trying to render some multilevel array using vue js. The array looks like

[ [ [ 0, "Hello", [ [ 0, "Test1", [ [ "25", "Test2", [ [ "26", "Test3", [ [ "30", "Test4", [ [ 45, "Test5", [ [ 56, "Test6", [ [ { "0": "Jan", "1": "1", "2": "0.0000", "3": "0.0000", "4": 0, "5": 0, "6": 0, "7": 0, "8": 0, "9": 1, "10": { "test10": true, "test90": false, }, "11": null, "test78": [ ] }, [ [ 123, 234 ], .........

and so on.

I want to take all the first elements of test6 array (jan, Feb .. ) and display horizontally. How can i code that using Vue Js and array map or reduce?

Thank you

Categories: Software

VUE component ignoring CSS

Vuejs - Mon, 2017-08-14 22:12

I have the following VUE component:

<template> <div> <div class="bottom-footer"> {{msg}} </div> </div> </template> <script> export default { name: 'LayoutFooter', data () { return { msg: 'my test' } }, mounted () { } } </script> <!-- Add "scoped" attribute to limit CSS to this component only --> <style scoped> .bottom-footer { height: 200px; background-color: #A7BFE8; } </scoped>

VUE is completely ignoring my scoped CSS. When page is rendered its simply not applied. There are no console errors. Ive tried removing the scoped attribute and its still ignored. Any ideas why VUE is doing this?

Categories: Software

Vue with Typescript - using components without definition

Vuejs - Mon, 2017-08-14 22:02

I'm trying to use vue-instant component as a child component. I'm not sure how to add components without definition, or maybe my issue is in the webpack config ignoring node_modules because of the lack of type? Here's what I have:

SingleUserSearch.vue (my custom component):

<template> <div class="input-group"> <vue-instant v-model="value" @input="changed" :suggestions="suggestions" name="customName" placeholder="custom placeholder" type="google"></vue-instant> </div> </template> <script lang="ts"> import Vue from "vue"; import Component from "vue-class-component"; import axios from "axios"; import VueInstant from 'vue-instant' let vueInstantComponent : Vue.Component = VueInstant; @Component({ components: { 'vue-instant': vueInstantComponent } }) export default class SingleUserSearch extends Vue { value:string=""; suggestions : Array<string> = [] async changed() { var that = this this.suggestions = [] let response = await axios.get('https://api.themoviedb.org/3/search/movie?api_key=342d3061b70d2747a1e159ae9a7e9a36&query=' + this.value); alert(response); } } </script>

Then I compile my code using webpack without difficulties. When I try to test the code on page I get:

[Vue warn]: Failed to mount component: template or render function not defined.

found in

---> at scripts\vue\components\SingleUserSearch.vue

webpack.config.js

var path = require('path'); var webpack = require('webpack'); module.exports = { entry: './scripts/vue/main.ts', output: { path: path.resolve('./scripts/build/'), filename: 'app.js' }, module: { loaders: [ { test: /\.tsx?$/, loader: 'ts-loader?' + JSON.stringify({ transpileOnly: true }) }, { test: /\.vue$/, loader:'vue-loader' }, { test: /\.js$/, loader: 'babel-loader', query: { presets: ['es2015','stage-0','stage-1','stage-2','stage-3'] } } ] }, resolve: { extensions: ['.js', '.vue'], alias: { 'vue': path.resolve('./node_modules/vue/dist/vue.esm.js') } }, stats: { colors: true }, devtool: 'source-map' };
Categories: Software

Computed property based on child components

Vuejs - Mon, 2017-08-14 21:28

Is it possible to create a computed property that relies on child components data? Seems like a trivial task but I can't figure it out...

foo component

<template> {{ foo }} </template> <script> export default { computed: { foo() { return Math.random() } } } </script>

parent component

<template> foo computed property sum: {{ sum }} <Foo v-for="n in 10"></Foo> </template> export default { computed: { sum() { // return...? } } } </script>
Categories: Software

npm install within Vagrant box but sudo npm run dev error

Vuejs - Mon, 2017-08-14 21:01

I installed npm in the Vagrant box, and when I tried to start the project, the error occurred. The error is as follows:

vagrant@vagrant-ubuntu-trusty-64:~$ sudo npm run dev npm ERR! Linux 3.13.0-121-generic npm ERR! argv "/opt/node-v6.11.2-linux-x64/bin/node" "/usr/local/bin/npm" "run" "dev" npm ERR! node v6.11.2 npm ERR! npm v3.10.10 npm ERR! path /home/vagrant/package.json npm ERR! code ENOENT npm ERR! errno -2 npm ERR! syscall open npm ERR! enoent ENOENT: no such file or directory, open '/home/vagrant/package.json' npm ERR! enoent ENOENT: no such file or directory, open '/home/vagrant/package.json' npm ERR! enoent This is most likely not a problem with npm itself npm ERR! enoent and is related to npm not being able to find a file. npm ERR! enoent npm ERR! Please include the following file with any support request: npm ERR! /home/vagrant/npm-debug.log

my Vagrantfile:

Vagrant.configure(2) do |config| config.vm.box = "~/Dev/WebstormProjects/ubuntu_former.box" config.vm.network "private_network", ip: "192.168.33.10" config.vm.synced_folder "../web-admin", "/vagrant_data" end

Please help me, and thank you

Categories: Software

Access component computed properties

Vuejs - Mon, 2017-08-14 20:01

Vue components exposes this.$data. Is there any way to access computed properties in a similar fashion?

They are not exposed on $data, and there is no such thing as this.$computed

Categories: Software

Show child component when promise data is exists and also render the data in child omponent

Vuejs - Mon, 2017-08-14 20:01

I am trying to implement search component for my application, parent component have the search text box and button. When the user provide some value i want to send the data to api and show the result in child component. I am bit confused where to call the api and also how to populate the data in child component. Also, initially my child component should not render in the parent component, when the search get some result then it can render. Please help me how to implement a search functionality in vue js 2.

Parent Component

<template> <div><h3> Search </h3></div> <div class="row"> <form role="search"> <div class="form-group col-lg-6 col-md-6"> <input type="text" v-model="searchKey" class="form-control"> </div> <div class="col-lg-6 col-md-6"> <button type="button" id="btn2" class="btn btn-danger btn-md" v-on:click="getInputValue">Search</button> </div> </form> </div> <result :searchdataShow='searchData'></result> </template> <script> import resultView from './result' export default { components: { 'result': resultView }, data () { return { searchKey: null, searchData: null } }, methods: { getInputValue: function(e) { console.log(this.searchKey) if(this.searchKey && this.searchKey != null) { this.$http.get('url').then((response) => { console.log(response.data) this.searchData = response.data }) } } } </script>

Search Result component(child component)

<template> <div> <div class="row"><h3> Search Results</h3></div> </div> </template> <script> export default { props: ['searchdataShow'] } </script>
Categories: Software

Is VueJS guaranteed to call mounted() in correct order?

Vuejs - Mon, 2017-08-14 19:46

Let's say I have a basic page with VueJS as follows:

Vue.component('child', { template: '<p>Placed at index {{index}}</p>', data() { return { index: 0 } }, mounted() { this.index = this.$parent.addElement(this); } }); new Vue({ el: '#theParent', data() { return { allElements: [] } }, methods: { addElement(elem) { this.allElements.push(elem); return this.allElements.length - 1; } } }); <script src="https://cdn.jsdelivr.net/vue/2.3.2/vue.min.js"></script> <div id="theParent"> <child></child> <child></child> <child></child> </div>

The purpose of the output is just to illustrate at what index the elements have been inserted at. My use case requires that the elements are added in the same order that they appear in the HTML. Every time I run this page it appears that this is indeed happening as the output is in order.

My question is: Is this behavior guaranteed to always happen - will VueJS always execute mounted() on components in the order they appear in the HTML? If not, is there an alternate way to guarantee that they are added to my array in the proper order?

Categories: Software

VueJS extend component: remove parent's property

Vuejs - Mon, 2017-08-14 19:43

I have two Vue components, one extends the other:

// CompA.vue export default { props: { value1: Object, }, data: function () { return { value2: 'hello2 from A', value3: 'hello3 from A' } } } // CompB.vue import CompA from './CompA.vue'; export default { extends: CompA, props: { value4: Object }, data: function(){ return { value2: 'hello2 from B' } } }

As described in the docs, CompB's options are merged into CompA's, resulting:

{ props: { value1: Object, value4: Object }, data: function () { return { value2: 'hello2 from B', value3: 'hello3 from A' } } }

However my desired result is having property value1 removed:

{ props: { value4: Object }, data: function () { return { value2: 'hello2 from B', value3: 'hello3 from A' } } }

I think it should be possible using Custom Option Merge Strategies

But even if I return null or undefined, the property isn't removed.

Vue.config.optionMergeStrategies.data = function(parentVal, childVal) { return null; };

Is it even possible to such thing? If yes, how?

Categories: Software

Including JS file in Vue.js 2 component

Vuejs - Mon, 2017-08-14 19:34

I have a JS file from here that I'd like to include in my single-file component.

I can't include the script tag in my template section, as that results in an error.

I also tried:

require('/static/sql.js'); import '/static/sql.js'

etc. following the instructions here.

in the script section of my .vue file, but those either complained that the file couldn't be found, or that the dependency wasn't installed. It's a large JS file (2 MB) so I'd prefer that it not be compiled by Vuejs/webpack. If I do an 'import', what function do I import from sql.js?

Should I instead install the node version of the sql.js library, along with its fs dependency? I would like to serve this as a static webpage, so I don't know if it makes sense to have the 'fs' module in there.

I'm currently just including the script tag in the index.html of my entire app, but would prefer that it just be loaded when I need this specific component.

Categories: Software

Pages