npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

vue-screen-orientation

v1.0.8

Published

Get easy and reactive access to the Direction, Version and Angle of your screen with vue.js.

Downloads

60

Readme

vue-screen-orientation

Get easy and reactive access to the Orientation of your screen.

Links

View demo

View on npm

View on GitHub

Install

# npm
npm i vue-screen-orientation

# yarn
yarn add vue-screen-orientation

Or you can include it through the browser at the bottom of your page:

<script src="https://unpkg.com/vue-screen-orientation/dist/vue-screen-orientation.min.js"></script>

About

Sometimes when building an app you need to have access to the screen's orientation. Usually that's going to be done in the css using @media - but sometimes you need to access that info right in your JavaScript.

The issue with this is you have to worry about adding event listeners and then removing them later. We wanted to just be able to import something quickly and then be able to forget about it later. So this mixin does just that - just use Vue.use() or mixins: [], and you're off.

There is something to consider - where and how you include this library. There are two ways, make sure to be aware of the differences:

Usage Example 1 - Whole app has access (Not Recommended)

In this usage - your whole app - and every child component - has access to the $vsoDirection, $vsoVersion, and $vsoAngle variables. This is sorta pollutive though, as multiple instances of the mixin are initialized and it's kinda wasteful. The is due to the way Vue mixins are passed down to child components. You can read more about this here. The second example is recommended.

import VueScreenOrientation from 'vue-screen-orientation'

const options = { vsoUse: VueScreenOrientation.VSO_USE_TYPE.AUTO }

Vue.use(VueScreenOrientation, options)
// Or 
Vue.use(VueScreenOrientation)

// Access `this.$vsoDirection`, `this.$vsoVersion`, and `this.$vsoAngle` anywhere in your app.

Usage Example 2 - Just the component you install it on has access - (Recommended)

In this usage - the component you install it on will have access to the $vsoDirection, $vsoVersion, and $vsoAngle variables. This may be a bit more restrictive, but it's less wasteful and should give you better performance.

import VueScreenOrientation from 'vue-screen-orientation'

const options = { vsoUse: VueScreenOrientation.VSO_USE_TYPE.AUTO }

export default {
    ...
    mixins: [VueScreenOrientation.mixin(options)],
    ...
}

// Or without options

export default {
    ...
    mixins: [VueScreenOrientation.mixin()],
    ...
}


// Access `this.$vsoDirection`, `this.$vsoVersion`, and `this.$vsoAngle` in your component.

Options of vsoUse

| name | description | |--------|------------| | VSO_USE_TYPE.AUTO | Orientation behavior is defined by default VSO_TYPE.ORIENTATION if supported. If not supported, VSO_TYPE.WINDOW is used | | VSO_USE_TYPE.ORIENTATION | Use window.screen.orientation object to get informations | | VSO_USE_TYPE.WINDOW | Calculate de informations based on window's sizes |

Variables

| name | type | description | Enum | |--------|------------|-------------|-------------| | $vsoDirection | String | The direction of your screen | portrait / landscape | | $vsoVersion | String | The version of your screen | primary / secondary | | $vsoAngle | Number | The angle rotation of screen | 0 ~ 360 |

Methods

| method | parameters | description | |--------|------------|-------------| | $vsoDestroyListener | none | Force the removal of the attached event listener |

Development

# install dependencies
npm install

# serve with hot reload
npm run watch

# run the tests
npm run test

# build demo page
npm run build:example

# build
npm run build

# publish to npm
npm publish

Other

Go ahead and fork the project! Submit an issue if needed. Have fun!

License

MIT

Packaged with a mixture of