diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml new file mode 100644 index 0000000..cb8a256 --- /dev/null +++ b/.github/workflows/release.yml @@ -0,0 +1,50 @@ +name: Release +on: + push: + branches: + - main + - master + +jobs: + release: + name: Release + runs-on: ubuntu-latest + permissions: + contents: write # to be able to publish a GitHub release + issues: write # to be able to comment on released issues + pull-requests: write # to be able to comment on released pull requests + id-token: write # to enable use of OIDC for npm provenance + + steps: + - name: Checkout + uses: actions/checkout@v4 + with: + fetch-depth: 0 + + - name: Setup Node.js + uses: actions/setup-node@v4 + with: + node-version: "lts/*" + cache: 'npm' + registry-url: 'https://registry.npmjs.org' + + - name: Install dependencies + run: npm ci + + - name: Verify the integrity of provenance attestations and registry signatures + run: npm audit signatures + + - name: Validate NPM_TOKEN + env: + NPM_TOKEN: ${{ secrets.NPM_TOKEN }} + run: | + if [ -z "$NPM_TOKEN" ]; then + echo "NPM_TOKEN is not set" + exit 1 + fi + + - name: Release + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + NPM_TOKEN: ${{ secrets.NPM_TOKEN }} + run: npx semantic-release diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml new file mode 100644 index 0000000..150aeeb --- /dev/null +++ b/.github/workflows/test.yml @@ -0,0 +1,31 @@ +name: Tests + +on: + push: + branches: [ main, master ] + pull_request: + branches: [ main, master ] + +jobs: + test: + runs-on: ubuntu-latest + + steps: + - uses: actions/checkout@v4 + + - name: Use Node.js + uses: actions/setup-node@v4 + with: + node-version: '20.x' + cache: 'npm' + + - name: Install dependencies + run: npm ci + + - name: Run tests + run: npm run test:single + + - name: Upload coverage + uses: codecov/codecov-action@v4 + env: + CODECOV_TOKEN: ${{ secrets.CODECOV_TOKEN }} \ No newline at end of file diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..1c45971 --- /dev/null +++ b/.gitignore @@ -0,0 +1,9 @@ +.idea +node_modules +.DS_Store +npm-debug.log +npm-debug.log.* +yarn-debug.log +yarn-debug.log.* +yarn-error.log~ +coverage \ No newline at end of file diff --git a/.npmrc b/.npmrc new file mode 100644 index 0000000..41d6205 --- /dev/null +++ b/.npmrc @@ -0,0 +1,2 @@ +registry=https://registry.npmjs.org/ +provenance=true \ No newline at end of file diff --git a/.releaserc.json: b/.releaserc.json: new file mode 100644 index 0000000..ae15ad0 --- /dev/null +++ b/.releaserc.json: @@ -0,0 +1,17 @@ +{ + "branches": ["main", "master"], + "plugins": [ + "@semantic-release/commit-analyzer", + "@semantic-release/release-notes-generator", + "@semantic-release/changelog", + "@semantic-release/npm", + "@semantic-release/github", + [ + "@semantic-release/git", + { + "assets": ["package.json", "CHANGELOG.md"], + "message": "chore(release): ${nextRelease.version} [skip ci]\n\n${nextRelease.notes}" + } + ] + ] +} \ No newline at end of file diff --git a/License.md b/LICENSE.md similarity index 100% rename from License.md rename to LICENSE.md diff --git a/Readme.md b/README.md similarity index 79% rename from Readme.md rename to README.md index a137ae8..1b5ba98 100644 --- a/Readme.md +++ b/README.md @@ -9,6 +9,8 @@ HTML5 like input number, but better ## Installation +### Simple + Include jQuery and `jquery.inputNumber.js` onto your page: ```html @@ -34,6 +36,20 @@ $('input.num').inputNumber({ }); ``` +### Npm + +```bash +npm install jquery-inputnumber +``` + +```javascript + +import InputNumber from 'jquery-inputnumber'; +import 'jquery-inputnumber/inputNumber.css'; + +$('input.num').inputNumber(); +``` + --- ## License diff --git a/component.json b/component.json deleted file mode 100644 index 06e3e3e..0000000 --- a/component.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "name": "jquery.inputNumber", - "version": "0.1.0", - "main": ["./jquery.inputNumber.js"], - "dependencies": { - "jquery": ">=1.7" - } -} \ No newline at end of file diff --git a/index.html b/index.html index 07e2e44..8772918 100644 --- a/index.html +++ b/index.html @@ -3,7 +3,7 @@ input number demo - + @@ -22,10 +22,10 @@ $(function() { $('input.num').inputNumber(); $('input.numNegative').inputNumber({ - positive: false, //deny positive numbers + positive: false //deny positive numbers }); $('input.numPositive').inputNumber({ - negative: false, //deny negative numbers + negative: false //deny negative numbers }); }); @@ -36,16 +36,16 @@
-
-
+
+
-
-
-
-
+
+
+
+
- \ No newline at end of file + diff --git a/inputNumber.css b/inputNumber.css index 01cbede..6b1bb5c 100644 --- a/inputNumber.css +++ b/inputNumber.css @@ -1,53 +1,46 @@ .ranged-input { - position: relative; - width: 52px; - height: 21px; - margin-right: 10px; -} - -.ranged-input a.up, -.ranged-input a.down { - right: 0; - display: block; - position: absolute; - cursor: pointer; - width: 20px; - height: 9px; - background-image: url(); - background-position: 0 0; - background-repeat: no-repeat; - border: 1px solid #cccccc; -} - -.ranged-input a.up { - top: 0; -} - -.ranged-input a.up:hover { - background-position: -20px 0; -} - -.ranged-input a.down { - background-position: 0 -9px; - bottom: 0; -} - -.ranged-input a.down:hover { - background-position: -20px -9px; -} - -.ranged-input input { - position: absolute; - left: 1px; - top: 0; - width: 28px; - font-size: 12px; - line-height: 12px; - height: 13px; - border: 1px solid #b3b3b3; - padding: 3px; -} - -.ranged-input input:focus { - outline: 0; -} \ No newline at end of file + position: relative; + width: 52px; + height: 21px; + margin-right: 10px; +} +.ranged-input__up, +.ranged-input__down { + right: 0; + display: block; + position: absolute; + cursor: pointer; + width: 20px; + height: 9px; + background-image: url(""); + background-position: 0 0; + background-repeat: no-repeat; + border: 1px solid #ccc; +} +.ranged-input__up { + top: 0; +} +.ranged-input__up:hover { + background-position: -20px 0; +} +.ranged-input__down { + background-position: 0 -9px; + bottom: 0; +} +.ranged-input__down:hover { + background-position: -20px -9px; +} +.ranged-input__input { + position: absolute; + left: 1px; + top: 0; + width: 28px; + font-size: 12px; + line-height: 12px; + height: 13px; + border: 1px solid #b3b3b3; + padding: 3px; +} +.ranged-input__input:focus { + outline: 0; +} diff --git a/inputNumber.styl b/inputNumber.styl new file mode 100644 index 0000000..dd6abf7 --- /dev/null +++ b/inputNumber.styl @@ -0,0 +1,49 @@ + +$ctx = ranged-input + +.{$ctx} + position relative + width 52px + height 21px + margin-right 10px + + &__up, + &__down + right 0 + display block + position absolute + cursor pointer + width 20px + height 9px + background-image url('') + background-position 0 0 + background-repeat no-repeat + border 1px solid #cccccc + + &__up + top 0 + + &:hover + background-position -20px 0 + + &__down + background-position 0 -9px + bottom 0 + + &:hover + background-position -20px -9px + + &__input + position absolute + left 1px + top 0 + width 28px + font-size 12px + line-height 12px + height 13px + border 1px solid #b3b3b3 + padding 3px + + &:focus + outline 0 + diff --git a/inputnumber.jquery.json b/inputnumber.jquery.json index 1ab68d6..acfeff1 100644 --- a/inputnumber.jquery.json +++ b/inputnumber.jquery.json @@ -1,30 +1,34 @@ { - "name":"inputnumber", - "version":"0.1.1", - "title":"jQuery HTML5 like input number", - "author": { - "name":"Nikolay Kostyurn", - "email":"jilizart@gmail.com" - }, - "description" : "Expand your default text input by number input features.", - "keywords" : [ - "number", - "html5", - "decimal", - "enumerable", - "input", - "form" - ], - "homepage" : "https://github.com/JiLiZART/jquery.inputNumber/", - "files" : ["jquery.inputNumber.js"], - "demo" : "http://jilizart.github.io/jquery.inputNumber/", - "dependencies" : { - "jquery" : ">1.7.0" - }, - "licenses" : [ - { - "type": "MIT", - "url": "https://github.com/JiLiZART/jquery.inputNumber/blob/master/License.md" - } - ] + "name": "inputnumber", + "version": "0.1.4", + "title": "jQuery HTML5 like input number", + "author": { + "name": "Nikolay Kostyurn", + "email": "jilizart@gmail.com" + }, + "description": "Expand your default text input by number input features.", + "keywords": [ + "jquery", + "number", + "html5", + "decimal", + "enumerable", + "input", + "form" + ], + "homepage": "https://github.com/JiLiZART/jquery.inputNumber/", + "files": [ + "jquery.inputNumber.js", + "inputNumber.css" + ], + "demo": "http://jilizart.github.io/jquery.inputNumber/", + "dependencies": { + "jquery": ">1.7.0" + }, + "licenses": [ + { + "type": "MIT", + "url": "https://github.com/JiLiZART/jquery.inputNumber/blob/master/LICENSE.md" + } + ] } diff --git a/jquery.inputNumber.js b/jquery.inputNumber.js index 031d3bb..2acf187 100644 --- a/jquery.inputNumber.js +++ b/jquery.inputNumber.js @@ -1,11 +1,40 @@ /** * @author Nikolay Kostyurin - * HTML5 Like enumerable input + * @version 0.1.4 HTML5 Like enumerable input */ -(function($) { + +// Uses CommonJS, AMD or browser globals to create a jQuery plugin. + +(function (factory) { + if (typeof define === 'function' && define.amd) { + // AMD. Register as an anonymous module. + define(['jquery'], factory); + } else if (typeof module === 'object' && module.exports) { + // Node/CommonJS + module.exports = function(root, jQuery) { + if (jQuery === undefined ) { + // require('jQuery') returns a factory that requires window to + // build a jQuery instance, we normalize how we use modules + // that require this pattern but the window provided is a noop + // if it's defined (how jquery works) + if (typeof window !== 'undefined' ) { + jQuery = require('jquery'); + } + else { + jQuery = require('jquery')(root); + } + } + factory(jQuery); + return jQuery; + }; + } else { + // Browser globals + factory(jQuery); + } +}(function ($) { 'use strict'; - var InputNumber = function(el, options) { + var InputNumber = function InputNumber(el, options) { this.el = el; this.$el = $(el); this.options = $.extend({}, this.defaults, options); @@ -13,55 +42,63 @@ }; InputNumber.prototype = { - el: null, // input element $el: null, // input element $wrap: null, //div wrapper element + $up: null, + $down: null, options: null, defaults: { - 'negative': true, - 'positive': true, - 'wrapClass': 'ranged-input', - 'upClass': 'up', - 'upTitle': 'incrase', - 'downClass': 'down', - 'downTitle': 'decrace' + min: -Infinity, + max: Infinity, + negative: true, + positive: true, + decimal: null, + wrapClass: 'ranged-input', + inputClass: 'ranged-input__input', + upClass: 'ranged-input__up', + upTitle: 'Incrase', + downClass: 'ranged-input__down', + downTitle: 'Decrace' }, init: function() { var opts = this.options; + + this.$up = $('