Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/weblineindia/vue-url-component
A VueJS based URL component provides option to add url (like Instagram url, Facebook url, web url, etc.) with validation. The URL value is automatically validated on blur event. You can even disable url field using disable props.
https://github.com/weblineindia/vue-url-component
url-validation urlcomponents vue vue-component vue-component-library vue-components vue-plugin vue-plugins vue-url vue-url-validation vuecomponent vuecomponents vuejs vuejs-component vuejs-components vuejs-library vuejs-plugin vuejs-snippets
Last synced: about 2 months ago
JSON representation
A VueJS based URL component provides option to add url (like Instagram url, Facebook url, web url, etc.) with validation. The URL value is automatically validated on blur event. You can even disable url field using disable props.
- Host: GitHub
- URL: https://github.com/weblineindia/vue-url-component
- Owner: weblineindia
- License: mit
- Created: 2020-06-26T12:05:01.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2023-12-27T08:01:26.000Z (about 1 year ago)
- Last Synced: 2024-11-07T14:17:14.488Z (about 2 months ago)
- Topics: url-validation, urlcomponents, vue, vue-component, vue-component-library, vue-components, vue-plugin, vue-plugins, vue-url, vue-url-validation, vuecomponent, vuecomponents, vuejs, vuejs-component, vuejs-components, vuejs-library, vuejs-plugin, vuejs-snippets
- Language: Vue
- Homepage: https://www.weblineindia.com/communities.html
- Size: 54.7 KB
- Stars: 1
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# VueJS URL Component
A Vue Url component is provide to add url (like instagramUrl,facebookUrl,webUrl, ..) with validation.
The Url value is automatically validated on blur event.
You can also disable url field using disable props.## Table of contents
- [Browser Support](#browser-support)
- [Demo](#demo)
- [Getting started](#getting-started)
- [Usage](#usage)
- [Available Props](#available-props)
- [Methods](#methods)
- [Want to Contribute?](#want-to-contribute)
- [Need Help / Support?](#need-help)
- [Collection of Components](#collection-of-components)
- [Changelog](#changelog)
- [License](#license)
- [Keywords](#Keywords)## Browser Support
| ![Chrome](https://raw.github.com/alrra/browser-logos/master/src/chrome/chrome_48x48.png) | ![Firefox](https://raw.github.com/alrra/browser-logos/master/src/firefox/firefox_48x48.png) | ![Safari](https://raw.github.com/alrra/browser-logos/master/src/safari/safari_48x48.png) | ![Edge](https://raw.github.com/alrra/browser-logos/master/src/edge/edge_48x48.png) | ![IE](https://raw.github.com/alrra/browser-logos/master/src/archive/internet-explorer_9-11/internet-explorer_9-11_48x48.png) |
| ---------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------------------- |
| 83.0 ✔ | 77.0 ✔ | 13.1.1 ✔ | 83.0 ✔ | 11.9 ✔ |## Demo
[![](url.gif)](https://github.com/weblineindia/Vue-URL-Component/url.gif)
## Getting started
Install the npm package:
```bash
npm install vue-weblineindia-url
#OR
yarn add vue-weblineindia-url
```## Usage
Use the `` component:
```vue
The url entered is not valid and must be changed
import URL from "vue-weblineindia-url";
export default {
components: { URL },
data: function() {
return {
urlValue: "",
invalidFacebookUrlError: false,
facebookUrlRegex: /(?:(?:http|https):\/\/)?(?:www.)?facebook.com\/(?:(?:\w)*#!\/)?(?:pages\/)?(?:[?\w\-]*\/)?(?:profile.php\?id=(?=\d.*))?([\w\-]*)?/ };
},methods: {
/** on focus url field */
onFocus(event) {
event.target.placeholder = "";
},
/** on blur url field */
onBlur(event, placeholder, errorObj) {
event.target.placeholder = placeholder;
const id = event.target.id;
this.showUrlErrorMsg(id, errorObj);
},
/**
* To show invalid url error msg
*/
showUrlErrorMsg(id, errorObject) {
if (errorObject.items.length > 0) {
errorObject.items.map(err => {
const urlId = err.field;
switch (urlId) {
case "facebookUrl":
this.invalidFacebookUrlError = true;
break;
}
});
}
},
/** on change value on url**/
onChangeUrl(value, id, index, error) {
this.invalidFacebookUrlError = false;
this.urlValue = value;
}
}
};```
## Available Props
| Prop | Type | default | Description |
| ------------------ | ------------------------------------------------------------------------- | ------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| value | String | | url value |
| socialType | String | FACEBOOK | url type |
| validationRegx | RegExp | | regex for url |
| placeholder | String | facebookUrl | url placeholder |
| disabled | Boolean | false | disable url field|
|name | String | facebookUrl | name for url field |
| tabindex | Number | 1 | url tabIndex |
| id | String | facebookUrl | name for url field |
| hide | Boolean | false | for hide url field |## Methods
| Name | Description |
| ------------ | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ |
| focus | Gets triggered when the url input field receives focus. |
| onBlur | Gets triggered when the url input field loses focus. |
| onChange | Gets triggered every time url got changed. |## Want to Contribute?
- Created something awesome, made this code better, added some functionality, or whatever (this is the hardest part).
- [Fork it](http://help.github.com/forking/).
- Create new branch to contribute your changes.
- Commit all your changes to your branch.
- Submit a [pull request](http://help.github.com/pull-requests/).---
## Need Help?
We also provide a free, basic support for all users who want to use this VueJS URL Component in their software project. In case you want to customize this Url component to suit your development needs, then feel free to contact our [VueJS developers](https://www.weblineindia.com/hire-vuejs-developer.html).
---
## Collection of Components
We have built many other components and free resources for software development in various programming languages. Kindly click here to view our [Free Resources for Software Development](https://www.weblineindia.com/communities.html)
---
## Changelog
Detailed changes for each release are documented in [CHANGELOG.md](./CHANGELOG.md).
## License
[MIT](LICENSE)
[mit]: https://github.com/weblineindia/Vue-URL-Component/blob/master/LICENSE
## Keywords
vue-weblineindia-url,url,vue components,vuejs,vuejs component