Security News
Research
Data Theft Repackaged: A Case Study in Malicious Wrapper Packages on npm
The Socket Research Team breaks down a malicious wrapper package that uses obfuscation to harvest credentials and exfiltrate sensitive data.
angularjs-slider
Advanced tools
AngularJS slider directive with no external dependencies. Mobile friendly!.
Slider directive implementation for AngularJS, without any dependencies.
Make sure the report is accompanied by a reproducible demo. The ideal demo is created by forking our standard jsFiddle, adding your own code and stripping it down to an absolute minimum needed to demonstrate the bug.
npm i angularjs-slider
or
$ bower install --save angularjs-slider
angular.module('yourApp', ['rzModule']);
// In your controller
$scope.priceSlider = 150;
<div>
<rzslider rz-slider-model="priceSlider"></rzslider>
</div>
Above example would render a slider from 0 to 150. If you need floor and ceiling values use rz-slider-options
attribute and provide an object with floor
and ceil
.
<div>
<rzslider
rz-slider-model="slider.value"
rz-slider-options="slider.options"></rzslider>
</div>
$scope.slider = {
value: 150,
options: {
floor: 0,
ceil: 450
}
};
If you don't want to bother with an object set in your javascript file, you can pass an anonymous object literal to the slider options:
<div>
<rzslider
rz-slider-model="value"
rz-slider-options="{floor: 0, ceil: 450}"></rzslider>
</div>
$scope.value = 150;
// In your controller
$scope.slider = {
min: 100,
max: 180,
options: {
floor: 0,
ceil: 450
}
};
<rzslider
rz-slider-model="slider.min"
rz-slider-high="slider.max"
rz-slider-options="slider.options"></rzslider>
rz-slider-model
Model for low value slider. If only rz-slider-model is provided single slider will be rendered.
rz-slider-high
Model for high value slider. Providing both rz-slider-model and rz-slider-high will render range slider.
rz-slider-options
An object with all the other options of the slider. Each option can be updated at runtime and the slider will automatically be re-rendered.
The default options are:
{
floor: 0,
ceil: null, //defaults to rz-slider-model
step: 1,
precision: 0,
translate: null,
id: null,
stepsArray: null,
draggableRange: false,
showSelectionBar: false,
hideLimitLabels: false,
readOnly: false,
disabled: false,
interval: 350,
showTicks: false,
showTicksValues: false,
scale: 1,
onStart: null,
onChange: null,
onEnd: null
}
floor - Number (defaults to 0): Minimum value for a slider.
ceil - Number (defaults to rz-slider-model
value): Maximum value for a slider.
step - Number (defaults to 1): Step between each value.
precision - Number (defaults to 0): The precision to display values with. The toFixed()
is used internally for this.
translate - Function(value, sliderId): Custom translate function. Use this if you want to translate values displayed on the slider. For example if you want to display dollar amounts instead of just numbers:
<div>
<rzslider
rz-slider-model="slider.value"
rz-slider-options="slider.options"></rzslider>
</div>
$scope.slider = {
value: 0,
options: {
floor: 0,
ceil: 100,
translate: function(value) {
return '$' + value;
}
}
};
id - Any (defaults to null): If you want to use the same translate
function for several sliders, just set the id
to anything you want, and it will be passed to the translate(value, sliderId)
function as a second argument.
stepsArray - Array: If you want to display a slider with non linear/number steps. Just pass an array with each slider value and that's it; the floor, ceil and step settings of the slider will be computed automatically. The rz-slider-model
value will be the index of the selected item in the stepsArray.
draggableRange - Boolean (defaults to false): When set to true and using a range slider, the range can be dragged by the selection bar. This doesn't work when ticks are shown.
showSelectionBar - Boolean (defaults to false): Set to true to always show the selection bar.
hideLimitLabels - Boolean (defaults to false): Set to true to hide min / max labels
readOnly - Boolean (defaults to false): Set to true to make the slider read-only.
disabled - Boolean (defaults to false): Set to true to disable the slider.
interval - Number in ms (defaults to 350): Internally, a throttle
function (See http://underscorejs.org/#throttle) is used when the model or high values of the slider are changed from outside the slider. This is to prevent from re-rendering the slider too many times in a row. interval
is the number of milliseconds to wait between two updates of the slider.
showTicks - Boolean (defaults to false): Set to true to display a tick for each step of the slider.
showTicksValues - Boolean (defaults to false): Set to true to display a tick and the step value for each step of the slider.
ticksValuesTooltip - Function(value) (defaults to null): (requires angular-ui bootstrap) Used to display a tooltip when a tick value is hovered. Set to a function that returns the tooltip content for a given value.
scale - Number (defaults to 1): If you display the slider in an element that uses transform: scale(0.5)
, set the scale
value to 2 so that the slider is rendered properly and the events are handled correctly.
onStart - Function(): Function to be called when a slider update is started.
onChange - Function(): Function to be called when rz-slider-model or rz-slider-high change.
onEnd - Function(): Function to be called when a slider update is ended.
If you want the change the default options for all the sliders displayed in your application, you can set them using the RzSliderOptions.options()
method:
angular.module('App', ['rzModule'])
.run(function( RzSliderOptions ) {
// show ticks for all sliders
RzSliderOptions.options( { showTicks: true } );
});
To force slider to recalculate dimensions, broadcast reCalcViewDimensions event from parent scope. This is useful for example when you use slider inside a widget where the content is hidden at start - see the "Sliders into modal" example on the demo site.
You can also force redraw with rzSliderForceRender event.
At the end of each "slide" slider emits slideEnded
event.
$scope.$on("slideEnded", function() {
// user finished sliding a handle
});
<script src="/path/to/angularjs/angular.min.js"></script>
<script src="/path/to/slider/rzslider.min.js"></script>
<script>
var YourApp = angular.module('myapp', ['rzModule']);
</script>
I use Slider on couple of my projects and it's being tested on desktop versions of Chrome, Firefox, Safari, IE 9/10 (Ticks are displayed using flex display so they don't work on IE9). Slider is also tested on Android and iPhone using all browsers available on those platforms.
This project is based on https://github.com/prajwalkman/angular-slider. It has been rewritten from scratch in JavaScript (the original source was written in CoffeeScript).
Licensed under the MIT license
2.0.0 (2015-11-12)
rzSliderModel
and rzSliderHigh
are moved to rzSliderOptions
. (See the new documentation in ReadMe)rzSliderOptions
attribute to pass options to the slider.RzSliderOptions.options()
method to set global options.scale
option to fix sliders displayed in an element that uses transform: scale(0.5)
.stepsArray
option (#163)id
option that is passed to the translate function as second arg (#161)ticksValuesTooltip
option that is used to display a tooltip on the ticks values (requires angular-ui bootstrap).FAQs
AngularJS slider directive with no external dependencies. Mobile friendly!.
The npm package angularjs-slider receives a total of 14,727 weekly downloads. As such, angularjs-slider popularity was classified as popular.
We found that angularjs-slider demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Research
The Socket Research Team breaks down a malicious wrapper package that uses obfuscation to harvest credentials and exfiltrate sensitive data.
Research
Security News
Attackers used a malicious npm package typosquatting a popular ESLint plugin to steal sensitive data, execute commands, and exploit developer systems.
Security News
The Ultralytics' PyPI Package was compromised four times in one weekend through GitHub Actions cache poisoning and failure to rotate previously compromised API tokens.