Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

ng-starrating

Package Overview
Dependencies
Maintainers
1
Versions
25
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

ng-starrating - npm Package Compare versions

Comparing version 1.0.13 to 1.0.14

51

bundles/ng-starrating.umd.js

@@ -233,3 +233,4 @@ (function (global, factory) {

_this.applyColorStyleAllStars(false);
_this.addRemoveEvents();
_this.addEvents();
//this.addRemoveEvents();
});

@@ -265,3 +266,4 @@ }

this.onReadOnlyChange.subscribe(function () {
_this.addRemoveEvents();
_this.readonly ? _this.makeReadOnly() : _this.makeEditable();
//this.addRemoveEvents();
});

@@ -339,12 +341,20 @@ }

});
// private makeEditable() {
// if (!this.mainElement) return;
// this.mainElement.nativeElement.addEventListener('mouseleave', this.offStar.bind(this));
// this.mainElement.nativeElement.style.cursor = "pointer";
// this.mainElement.nativeElement.title = this.value;
// this.stars.forEach((star: any) => {
// star.addEventListener('click', this.onRate.bind(this));
// star.addEventListener('mouseenter', this.onStar.bind(this));
// star.style.cursor = "pointer";
// star.title = star.dataset.index;
// });
// }
StarRatingComponent.prototype.makeEditable = function () {
var _this = this;
if (!this.mainElement)
return;
this.mainElement.nativeElement.addEventListener('mouseleave', this.offStar.bind(this));
this.mainElement.nativeElement.style.cursor = "pointer";
this.mainElement.nativeElement.title = this.value;
this.stars.forEach(function (star) {
star.addEventListener('click', _this.onRate.bind(_this));
star.addEventListener('mouseenter', _this.onStar.bind(_this));
star.style.cursor = "pointer";

@@ -364,10 +374,23 @@ star.title = star.dataset.index;

};
StarRatingComponent.prototype.addRemoveEvents = function () {
if (this.readonly) {
this.makeReadOnly();
}
else {
this.makeEditable();
this.onValueChange.next(this.value);
}
// private addRemoveEvents() {
// if (this.readonly) {
// this.makeReadOnly();
// } else {
// this.makeEditable();
// this.onValueChange.next(this.value);
// }
// }
StarRatingComponent.prototype.addEvents = function () {
var _this = this;
if (!this.mainElement)
return;
this.mainElement.nativeElement.addEventListener('mouseleave', this.offStar.bind(this));
this.mainElement.nativeElement.style.cursor = "pointer";
this.mainElement.nativeElement.title = this.value;
this.stars.forEach(function (star) {
star.addEventListener('click', _this.onRate.bind(_this));
star.addEventListener('mouseenter', _this.onStar.bind(_this));
star.style.cursor = "pointer";
star.title = star.dataset.index;
});
};

@@ -374,0 +397,0 @@ StarRatingComponent.prototype.ngAfterViewInit = function () {

@@ -1,2 +0,2 @@

!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("@angular/forms"),require("@angular/common"),require("rxjs")):"function"==typeof define&&define.amd?define("ng-starrating",["exports","@angular/core","@angular/forms","@angular/common","rxjs"],t):t((e=e||self)["ng-starrating"]={},e.ng.core,e.ng.forms,e.ng.common,e.rxjs)}(this,(function(e,t,n,r,o){"use strict";
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("@angular/forms"),require("@angular/common"),require("rxjs")):"function"==typeof define&&define.amd?define("ng-starrating",["exports","@angular/core","@angular/forms","@angular/common","rxjs"],t):t((e=e||self)["ng-starrating"]={},e.ng.core,e.ng.forms,e.ng.common,e.rxjs)}(this,(function(e,t,n,r,a){"use strict";
/*! *****************************************************************************

@@ -15,3 +15,3 @@ Copyright (c) Microsoft Corporation. All rights reserved.

and limitations under the License.
***************************************************************************** */function a(e,t,n,r){var o,a=arguments.length,i=a<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,n):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,n,r);else for(var s=e.length-1;s>=0;s--)(o=e[s])&&(i=(a<3?o(i):a>3?o(t,n,i):o(t,n))||i);return a>3&&i&&Object.defineProperty(t,n,i),i}function i(e,t){if("object"==typeof Reflect&&"function"==typeof Reflect.metadata)return Reflect.metadata(e,t)}function s(e,t){var n="function"==typeof Symbol&&e[Symbol.iterator];if(!n)return e;var r,o,a=n.call(e),i=[];try{for(;(void 0===t||t-- >0)&&!(r=a.next()).done;)i.push(r.value)}catch(e){o={error:e}}finally{try{r&&!r.done&&(n=a.return)&&n.call(a)}finally{if(o)throw o.error}}return i}var l=function(){function e(){}return e.prototype.ngOnInit=function(){},e=a([t.Component({selector:"lib-rating",template:"\n <p>\n rating works!\n </p>\n "}),i("design:paramtypes",[])],e)}(),c=function(){function e(){var e=this;this.stars=[],this._readOnly=!1,this._totalStars=5,this.rate=new t.EventEmitter,this.onStarsCountChange||(this.onStarsCountChange=new o.Subject,this.onStarsCountChange.subscribe((function(){e.setStars(),e.generateRating(!0),e.applySizeAllStars(),e.applyColorStyleAllStars(!1),e.addRemoveEvents()}))),this.onValueChange||(this.onValueChange=new o.Subject,this.onValueChange.subscribe((function(){e.generateRating(),e.applySizeAllStars()}))),this.onCheckedColorChange||(this.onCheckedColorChange=new o.Subject,this.onCheckedColorChange.subscribe((function(){e.applyColorStyleAllStars(!0)}))),this.onUnCheckedColorChange||(this.onUnCheckedColorChange=new o.Subject,this.onUnCheckedColorChange.subscribe((function(){e.applyColorStyleAllStars(!1)}))),this.onSizeChange||(this.onSizeChange=new o.Subject,this.onSizeChange.subscribe((function(){e.applySizeAllStars()}))),this.onReadOnlyChange||(this.onReadOnlyChange=new o.Subject,this.onReadOnlyChange.subscribe((function(){e.addRemoveEvents()})))}var n;return n=e,Object.defineProperty(e.prototype,"checkedcolor",{get:function(){return this._checkedColor},set:function(e){this._checkedColor=e,this._checkedColor&&this.onCheckedColorChange.next(this._checkedColor)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"uncheckedcolor",{get:function(){return this._unCheckedColor},set:function(e){this._unCheckedColor=e,this._unCheckedColor&&this.onUnCheckedColorChange.next(this._unCheckedColor)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"value",{get:function(){return this._value},set:function(e){e=e&&null!=e?e:0,this._value=e,this._value>=0&&this.onValueChange.next(this._value)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"size",{get:function(){return this._size.concat(this._size.includes("px")?"":"px")},set:function(e){e=e&&null!=e&&"0px"!=e?e:"24px",this._size=e,this.onSizeChange.next(this._size)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"readonly",{get:function(){return"true"===String(this._readOnly)},set:function(e){this._readOnly=e,this.onReadOnlyChange.next(e)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"totalstars",{get:function(){return this._totalStars},set:function(e){this._totalStars=e<=0?5:e,this.onStarsCountChange.next(Number(e))},enumerable:!0,configurable:!0}),e.prototype.makeEditable=function(){var e=this;this.mainElement&&(this.mainElement.nativeElement.addEventListener("mouseleave",this.offStar.bind(this)),this.mainElement.nativeElement.style.cursor="pointer",this.mainElement.nativeElement.title=this.value,this.stars.forEach((function(t){t.addEventListener("click",e.onRate.bind(e)),t.addEventListener("mouseenter",e.onStar.bind(e)),t.style.cursor="pointer",t.title=t.dataset.index})))},e.prototype.makeReadOnly=function(){this.mainElement&&(this.mainElement.nativeElement.style.cursor="default",this.mainElement.nativeElement.title=this.value,this.stars.forEach((function(e){e.style.cursor="default",e.title=""})))},e.prototype.addRemoveEvents=function(){this.readonly?this.makeReadOnly():(this.makeEditable(),this.onValueChange.next(this.value))},e.prototype.ngAfterViewInit=function(){},e.prototype.onRate=function(e){if(!this.readonly){var t=e.srcElement,n=this.value;this.value=parseInt(t.dataset.index),0==this.value&&(this.value=1);var r={oldValue:n,newValue:this.value,starRating:this};this.rate.emit(r)}},e.prototype.onStar=function(e){if(!this.readonly){for(var t=e.srcElement,n=parseInt(t.dataset.index),r=0;r<n;r++)this.stars[r].className="",this.addDefaultClass(this.stars[r]),this.addCheckedStarClass(this.stars[r]);for(r=n;r<this.stars.length;r++)this.stars[r].className="",this.addDefaultClass(this.stars[r])}},e.prototype.offStar=function(e){this.generateRating()},e.prototype.addDefaultClass=function(e){e.classList.add(n.CLS_DEFAULT_STAR)},e.prototype.addCheckedStarClass=function(e){e.classList.add(n.CLS_CHECKED_STAR)},e.prototype.addHalfStarClass=function(e){e.classList.add(n.CLS_HALF_STAR)},e.prototype.setStars=function(){var e=this;if(this.mainElement){var t=this.mainElement.nativeElement,n=function(){for(var e=[],t=0;t<arguments.length;t++)e=e.concat(s(arguments[t]));return e}(Array(Number(this.totalstars)).keys());this.stars.length=0,t.innerHTML="",n.forEach((function(n){var r=document.createElement("span");r.dataset.index=(n+1).toString(),r.title=r.dataset.index,t.appendChild(r),e.stars.push(r)}))}},e.prototype.applySizeAllStars=function(){var e=this;this._size&&(0==this.stars.length&&this.setStars(),this.stars.forEach((function(t){var r=e.size.match(/\d+/)[0],o=10*parseInt(r)/24,a=0-20*parseInt(r)/24;t.style.setProperty(n.VAR_SIZE,e.size),t.classList.contains(n.CLS_HALF_STAR)&&(t.style.setProperty(n.VAR_HALF_WIDTH,o+"px"),t.style.setProperty(n.VAR_HALF_MARGIN,a+"px"))})))},e.prototype.applyColorStyleAllStars=function(e){var t=this;0==this.stars.length&&this.setStars(),this.stars.forEach((function(n){e?t.applyCheckedColorStyle(n):t.applyUnCheckedColorStyle(n)}))},e.prototype.applyColorStyle=function(e){this.applyCheckedColorStyle(e),this.applyUnCheckedColorStyle(e)},e.prototype.applyCheckedColorStyle=function(e){e.style.setProperty(n.VAR_CHECKED_COLOR,this.checkedcolor)},e.prototype.applyUnCheckedColorStyle=function(e){e.style.setProperty(n.VAR_UNCHECKED_COLOR,this.uncheckedcolor)},e.prototype.generateRating=function(e){var t=this;if(void 0===e&&(e=!1),(!this.readonly||e)&&this.mainElement&&(0==this.stars.length&&this.setStars(),this.value>=0)){this.mainElement.nativeElement.title=this.value;var n=!!(Number.parseFloat(this.value.toString())%1).toString().substring(3,2),r=1;this.stars.forEach((function(e){e.className="",t.applyColorStyle(e),t.addDefaultClass(e),t.value>=r?t.addCheckedStarClass(e):n&&(t.addHalfStarClass(e),n=!1),r++}))}},e.VAR_CHECKED_COLOR="--checkedColor",e.VAR_UNCHECKED_COLOR="--unCheckedColor",e.VAR_SIZE="--size",e.VAR_HALF_WIDTH="--halfWidth",e.VAR_HALF_MARGIN="--halfMargin",e.CLS_CHECKED_STAR="on",e.CLS_DEFAULT_STAR="star",e.CLS_HALF_STAR="half",e.INP_CHECKED_COLOR="checkedcolor",e.INP_UNCHECKED_COLOR="uncheckedcolor",e.INP_VALUE="value",e.INP_SIZE="size",e.INP_READONLY="readonly",e.INP_TOTALSTARS="totalstars",a([t.ViewChild("starMain",{static:!0}),i("design:type",t.ElementRef)],e.prototype,"mainElement",void 0),a([t.Output(),i("design:type",t.EventEmitter)],e.prototype,"rate",void 0),a([t.Input(n.INP_CHECKED_COLOR),i("design:type",String),i("design:paramtypes",[String])],e.prototype,"checkedcolor",null),a([t.Input(n.INP_UNCHECKED_COLOR),i("design:type",String),i("design:paramtypes",[String])],e.prototype,"uncheckedcolor",null),a([t.Input(n.INP_VALUE),i("design:type",Number),i("design:paramtypes",[Number])],e.prototype,"value",null),a([t.Input(n.INP_SIZE),i("design:type",String),i("design:paramtypes",[String])],e.prototype,"size",null),a([t.Input(n.INP_READONLY),i("design:type",Boolean),i("design:paramtypes",[Boolean])],e.prototype,"readonly",null),a([t.Input(n.INP_TOTALSTARS),i("design:type",Number),i("design:paramtypes",[Number])],e.prototype,"totalstars",null),e=n=a([t.Component({selector:"star-rating",template:'<div #starMain>\r\n</div>\r\n\r\n\x3c!-- <ng-container *ngFor="let star of stars; let i = index;">\r\n <span \r\n (click)="!isReadOnly && onRate(i)" \r\n (mouseleave)="!isReadOnly && generateRating()"\r\n (mouseenter)="!isReadOnly && onStar(i)" \r\n [ngStyle]="{\r\n \'font-size\': getSize(),\r\n \'width\': getSize(),\r\n pointer: isReadOnly ? \'default\' : \'pointer\'\r\n }" \r\n [ngClass]="{\r\n on: star.checked,\r\n half: star.isHalf,\r\n readOnly: isReadOnly,\r\n editable: !isReadOnly\r\n }"></span>\r\n</ng-container> --\x3e',encapsulation:t.ViewEncapsulation.ShadowDom,styles:[":root{--checkedColor:gold;--unCheckedColor:gray;--size:24px;--halfWidth:10px;--halfMargin:-20px}.star{cursor:pointer;color:var(--unCheckedColor);font-size:var(--size);width:var(--size);display:inline-block}.star:last-child{margin-right:0}.star:before{content:'\\2605'}.star.on{color:var(--checkedColor)}.star.half:after{content:'\\2605';color:var(--checkedColor);position:absolute;margin-left:var(--halfMargin);width:var(--halfWidth);overflow:hidden}"]}),i("design:paramtypes",[])],e)}(),h=function(){function e(){}return e.prototype.ngDoBootstrap=function(){},e=a([t.NgModule({imports:[n.FormsModule,r.CommonModule],declarations:[l,c],exports:[c],entryComponents:[c]})],e)}();e.RatingModule=h,e.StarRatingComponent=c,e.ɵa=l,Object.defineProperty(e,"__esModule",{value:!0})}));
***************************************************************************** */function o(e,t,n,r){var a,o=arguments.length,i=o<3?t:null===r?r=Object.getOwnPropertyDescriptor(t,n):r;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,n,r);else for(var s=e.length-1;s>=0;s--)(a=e[s])&&(i=(o<3?a(i):o>3?a(t,n,i):a(t,n))||i);return o>3&&i&&Object.defineProperty(t,n,i),i}function i(e,t){if("object"==typeof Reflect&&"function"==typeof Reflect.metadata)return Reflect.metadata(e,t)}function s(e,t){var n="function"==typeof Symbol&&e[Symbol.iterator];if(!n)return e;var r,a,o=n.call(e),i=[];try{for(;(void 0===t||t-- >0)&&!(r=o.next()).done;)i.push(r.value)}catch(e){a={error:e}}finally{try{r&&!r.done&&(n=o.return)&&n.call(o)}finally{if(a)throw a.error}}return i}var l=function(){function e(){}return e.prototype.ngOnInit=function(){},e=o([t.Component({selector:"lib-rating",template:"\n <p>\n rating works!\n </p>\n "}),i("design:paramtypes",[])],e)}(),c=function(){function e(){var e=this;this.stars=[],this._readOnly=!1,this._totalStars=5,this.rate=new t.EventEmitter,this.onStarsCountChange||(this.onStarsCountChange=new a.Subject,this.onStarsCountChange.subscribe((function(){e.setStars(),e.generateRating(!0),e.applySizeAllStars(),e.applyColorStyleAllStars(!1),e.addEvents()}))),this.onValueChange||(this.onValueChange=new a.Subject,this.onValueChange.subscribe((function(){e.generateRating(),e.applySizeAllStars()}))),this.onCheckedColorChange||(this.onCheckedColorChange=new a.Subject,this.onCheckedColorChange.subscribe((function(){e.applyColorStyleAllStars(!0)}))),this.onUnCheckedColorChange||(this.onUnCheckedColorChange=new a.Subject,this.onUnCheckedColorChange.subscribe((function(){e.applyColorStyleAllStars(!1)}))),this.onSizeChange||(this.onSizeChange=new a.Subject,this.onSizeChange.subscribe((function(){e.applySizeAllStars()}))),this.onReadOnlyChange||(this.onReadOnlyChange=new a.Subject,this.onReadOnlyChange.subscribe((function(){e.readonly?e.makeReadOnly():e.makeEditable()})))}var n;return n=e,Object.defineProperty(e.prototype,"checkedcolor",{get:function(){return this._checkedColor},set:function(e){this._checkedColor=e,this._checkedColor&&this.onCheckedColorChange.next(this._checkedColor)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"uncheckedcolor",{get:function(){return this._unCheckedColor},set:function(e){this._unCheckedColor=e,this._unCheckedColor&&this.onUnCheckedColorChange.next(this._unCheckedColor)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"value",{get:function(){return this._value},set:function(e){e=e&&null!=e?e:0,this._value=e,this._value>=0&&this.onValueChange.next(this._value)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"size",{get:function(){return this._size.concat(this._size.includes("px")?"":"px")},set:function(e){e=e&&null!=e&&"0px"!=e?e:"24px",this._size=e,this.onSizeChange.next(this._size)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"readonly",{get:function(){return"true"===String(this._readOnly)},set:function(e){this._readOnly=e,this.onReadOnlyChange.next(e)},enumerable:!0,configurable:!0}),Object.defineProperty(e.prototype,"totalstars",{get:function(){return this._totalStars},set:function(e){this._totalStars=e<=0?5:e,this.onStarsCountChange.next(Number(e))},enumerable:!0,configurable:!0}),e.prototype.makeEditable=function(){this.mainElement&&(this.mainElement.nativeElement.style.cursor="pointer",this.mainElement.nativeElement.title=this.value,this.stars.forEach((function(e){e.style.cursor="pointer",e.title=e.dataset.index})))},e.prototype.makeReadOnly=function(){this.mainElement&&(this.mainElement.nativeElement.style.cursor="default",this.mainElement.nativeElement.title=this.value,this.stars.forEach((function(e){e.style.cursor="default",e.title=""})))},e.prototype.addEvents=function(){var e=this;this.mainElement&&(this.mainElement.nativeElement.addEventListener("mouseleave",this.offStar.bind(this)),this.mainElement.nativeElement.style.cursor="pointer",this.mainElement.nativeElement.title=this.value,this.stars.forEach((function(t){t.addEventListener("click",e.onRate.bind(e)),t.addEventListener("mouseenter",e.onStar.bind(e)),t.style.cursor="pointer",t.title=t.dataset.index})))},e.prototype.ngAfterViewInit=function(){},e.prototype.onRate=function(e){if(!this.readonly){var t=e.srcElement,n=this.value;this.value=parseInt(t.dataset.index),0==this.value&&(this.value=1);var r={oldValue:n,newValue:this.value,starRating:this};this.rate.emit(r)}},e.prototype.onStar=function(e){if(!this.readonly){for(var t=e.srcElement,n=parseInt(t.dataset.index),r=0;r<n;r++)this.stars[r].className="",this.addDefaultClass(this.stars[r]),this.addCheckedStarClass(this.stars[r]);for(r=n;r<this.stars.length;r++)this.stars[r].className="",this.addDefaultClass(this.stars[r])}},e.prototype.offStar=function(e){this.generateRating()},e.prototype.addDefaultClass=function(e){e.classList.add(n.CLS_DEFAULT_STAR)},e.prototype.addCheckedStarClass=function(e){e.classList.add(n.CLS_CHECKED_STAR)},e.prototype.addHalfStarClass=function(e){e.classList.add(n.CLS_HALF_STAR)},e.prototype.setStars=function(){var e=this;if(this.mainElement){var t=this.mainElement.nativeElement,n=function(){for(var e=[],t=0;t<arguments.length;t++)e=e.concat(s(arguments[t]));return e}(Array(Number(this.totalstars)).keys());this.stars.length=0,t.innerHTML="",n.forEach((function(n){var r=document.createElement("span");r.dataset.index=(n+1).toString(),r.title=r.dataset.index,t.appendChild(r),e.stars.push(r)}))}},e.prototype.applySizeAllStars=function(){var e=this;this._size&&(0==this.stars.length&&this.setStars(),this.stars.forEach((function(t){var r=e.size.match(/\d+/)[0],a=10*parseInt(r)/24,o=0-20*parseInt(r)/24;t.style.setProperty(n.VAR_SIZE,e.size),t.classList.contains(n.CLS_HALF_STAR)&&(t.style.setProperty(n.VAR_HALF_WIDTH,a+"px"),t.style.setProperty(n.VAR_HALF_MARGIN,o+"px"))})))},e.prototype.applyColorStyleAllStars=function(e){var t=this;0==this.stars.length&&this.setStars(),this.stars.forEach((function(n){e?t.applyCheckedColorStyle(n):t.applyUnCheckedColorStyle(n)}))},e.prototype.applyColorStyle=function(e){this.applyCheckedColorStyle(e),this.applyUnCheckedColorStyle(e)},e.prototype.applyCheckedColorStyle=function(e){e.style.setProperty(n.VAR_CHECKED_COLOR,this.checkedcolor)},e.prototype.applyUnCheckedColorStyle=function(e){e.style.setProperty(n.VAR_UNCHECKED_COLOR,this.uncheckedcolor)},e.prototype.generateRating=function(e){var t=this;if(void 0===e&&(e=!1),(!this.readonly||e)&&this.mainElement&&(0==this.stars.length&&this.setStars(),this.value>=0)){this.mainElement.nativeElement.title=this.value;var n=!!(Number.parseFloat(this.value.toString())%1).toString().substring(3,2),r=1;this.stars.forEach((function(e){e.className="",t.applyColorStyle(e),t.addDefaultClass(e),t.value>=r?t.addCheckedStarClass(e):n&&(t.addHalfStarClass(e),n=!1),r++}))}},e.VAR_CHECKED_COLOR="--checkedColor",e.VAR_UNCHECKED_COLOR="--unCheckedColor",e.VAR_SIZE="--size",e.VAR_HALF_WIDTH="--halfWidth",e.VAR_HALF_MARGIN="--halfMargin",e.CLS_CHECKED_STAR="on",e.CLS_DEFAULT_STAR="star",e.CLS_HALF_STAR="half",e.INP_CHECKED_COLOR="checkedcolor",e.INP_UNCHECKED_COLOR="uncheckedcolor",e.INP_VALUE="value",e.INP_SIZE="size",e.INP_READONLY="readonly",e.INP_TOTALSTARS="totalstars",o([t.ViewChild("starMain",{static:!0}),i("design:type",t.ElementRef)],e.prototype,"mainElement",void 0),o([t.Output(),i("design:type",t.EventEmitter)],e.prototype,"rate",void 0),o([t.Input(n.INP_CHECKED_COLOR),i("design:type",String),i("design:paramtypes",[String])],e.prototype,"checkedcolor",null),o([t.Input(n.INP_UNCHECKED_COLOR),i("design:type",String),i("design:paramtypes",[String])],e.prototype,"uncheckedcolor",null),o([t.Input(n.INP_VALUE),i("design:type",Number),i("design:paramtypes",[Number])],e.prototype,"value",null),o([t.Input(n.INP_SIZE),i("design:type",String),i("design:paramtypes",[String])],e.prototype,"size",null),o([t.Input(n.INP_READONLY),i("design:type",Boolean),i("design:paramtypes",[Boolean])],e.prototype,"readonly",null),o([t.Input(n.INP_TOTALSTARS),i("design:type",Number),i("design:paramtypes",[Number])],e.prototype,"totalstars",null),e=n=o([t.Component({selector:"star-rating",template:'<div #starMain>\r\n</div>\r\n\r\n\x3c!-- <ng-container *ngFor="let star of stars; let i = index;">\r\n <span \r\n (click)="!isReadOnly && onRate(i)" \r\n (mouseleave)="!isReadOnly && generateRating()"\r\n (mouseenter)="!isReadOnly && onStar(i)" \r\n [ngStyle]="{\r\n \'font-size\': getSize(),\r\n \'width\': getSize(),\r\n pointer: isReadOnly ? \'default\' : \'pointer\'\r\n }" \r\n [ngClass]="{\r\n on: star.checked,\r\n half: star.isHalf,\r\n readOnly: isReadOnly,\r\n editable: !isReadOnly\r\n }"></span>\r\n</ng-container> --\x3e',encapsulation:t.ViewEncapsulation.ShadowDom,styles:[":root{--checkedColor:gold;--unCheckedColor:gray;--size:24px;--halfWidth:10px;--halfMargin:-20px}.star{cursor:pointer;color:var(--unCheckedColor);font-size:var(--size);width:var(--size);display:inline-block}.star:last-child{margin-right:0}.star:before{content:'\\2605'}.star.on{color:var(--checkedColor)}.star.half:after{content:'\\2605';color:var(--checkedColor);position:absolute;margin-left:var(--halfMargin);width:var(--halfWidth);overflow:hidden}"]}),i("design:paramtypes",[])],e)}(),h=function(){function e(){}return e.prototype.ngDoBootstrap=function(){},e=o([t.NgModule({imports:[n.FormsModule,r.CommonModule],declarations:[l,c],exports:[c],entryComponents:[c]})],e)}();e.RatingModule=h,e.StarRatingComponent=c,e.ɵa=l,Object.defineProperty(e,"__esModule",{value:!0})}));
//# sourceMappingURL=ng-starrating.umd.min.js.map

@@ -51,3 +51,3 @@ import { EventEmitter } from '@angular/core';

private makeReadOnly;
private addRemoveEvents;
private addEvents;
private ngAfterViewInit;

@@ -54,0 +54,0 @@ private onRate;

@@ -18,3 +18,4 @@ var StarRatingComponent_1;

this.applyColorStyleAllStars(false);
this.addRemoveEvents();
this.addEvents();
//this.addRemoveEvents();
});

@@ -50,3 +51,4 @@ }

this.onReadOnlyChange.subscribe(() => {
this.addRemoveEvents();
this.readonly ? this.makeReadOnly() : this.makeEditable();
//this.addRemoveEvents();
});

@@ -99,11 +101,20 @@ }

}
// private makeEditable() {
// if (!this.mainElement) return;
// this.mainElement.nativeElement.addEventListener('mouseleave', this.offStar.bind(this));
// this.mainElement.nativeElement.style.cursor = "pointer";
// this.mainElement.nativeElement.title = this.value;
// this.stars.forEach((star: any) => {
// star.addEventListener('click', this.onRate.bind(this));
// star.addEventListener('mouseenter', this.onStar.bind(this));
// star.style.cursor = "pointer";
// star.title = star.dataset.index;
// });
// }
makeEditable() {
if (!this.mainElement)
return;
this.mainElement.nativeElement.addEventListener('mouseleave', this.offStar.bind(this));
this.mainElement.nativeElement.style.cursor = "pointer";
this.mainElement.nativeElement.title = this.value;
this.stars.forEach((star) => {
star.addEventListener('click', this.onRate.bind(this));
star.addEventListener('mouseenter', this.onStar.bind(this));
star.style.cursor = "pointer";

@@ -123,10 +134,22 @@ star.title = star.dataset.index;

}
addRemoveEvents() {
if (this.readonly) {
this.makeReadOnly();
}
else {
this.makeEditable();
this.onValueChange.next(this.value);
}
// private addRemoveEvents() {
// if (this.readonly) {
// this.makeReadOnly();
// } else {
// this.makeEditable();
// this.onValueChange.next(this.value);
// }
// }
addEvents() {
if (!this.mainElement)
return;
this.mainElement.nativeElement.addEventListener('mouseleave', this.offStar.bind(this));
this.mainElement.nativeElement.style.cursor = "pointer";
this.mainElement.nativeElement.title = this.value;
this.stars.forEach((star) => {
star.addEventListener('click', this.onRate.bind(this));
star.addEventListener('mouseenter', this.onStar.bind(this));
star.style.cursor = "pointer";
star.title = star.dataset.index;
});
}

@@ -322,2 +345,2 @@ ngAfterViewInit() {

export { StarRatingComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"star-rating.component.js","sourceRoot":"ng://ng-starrating/","sources":["components/star-rating/star-rating.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, ViewChild, ElementRef, \r\n  EventEmitter, ViewEncapsulation } from '@angular/core';\r\nimport { Subject } from 'rxjs';\r\n\r\n@Component({\r\n  selector: 'star-rating',\r\n  templateUrl: './star-rating.component.html',\r\n  styleUrls: ['./star-rating.component.css'],\r\n  encapsulation: ViewEncapsulation.ShadowDom\r\n})\r\n\r\nexport class StarRatingComponent {\r\n  private stars: Array<Element> = [];\r\n  \r\n  private _checkedColor: string;\r\n  private _unCheckedColor: string;\r\n  private _value: number;\r\n  private _size: string;\r\n  private _readOnly: boolean = false;\r\n\r\n  private _totalStars: number = 5;\r\n  private onStarsCountChange: Subject<number>;\r\n  private onValueChange: Subject<number>;\r\n  private onCheckedColorChange: Subject<string>;\r\n  private onUnCheckedColorChange: Subject<string>;\r\n  private onSizeChange: Subject<string>;\r\n  private onReadOnlyChange: Subject<boolean>;\r\n\r\n  private static readonly VAR_CHECKED_COLOR: string = '--checkedColor';\r\n  private static readonly VAR_UNCHECKED_COLOR: string = '--unCheckedColor';\r\n  private static readonly VAR_SIZE: string = '--size';\r\n  private static readonly VAR_HALF_WIDTH: string = '--halfWidth';\r\n  private static readonly VAR_HALF_MARGIN: string = '--halfMargin';\r\n  private static readonly CLS_CHECKED_STAR: string = 'on';\r\n  private static readonly CLS_DEFAULT_STAR: string = 'star';\r\n  private static readonly CLS_HALF_STAR: string = 'half';\r\n  private static readonly INP_CHECKED_COLOR: string = 'checkedcolor';\r\n  private static readonly INP_UNCHECKED_COLOR: string = 'uncheckedcolor';\r\n  private static readonly INP_VALUE: string = 'value';\r\n  private static readonly INP_SIZE: string = 'size';\r\n  private static readonly INP_READONLY: string = 'readonly';\r\n  private static readonly INP_TOTALSTARS: string = 'totalstars';\r\n\r\n  @ViewChild('starMain', { static: true }) private mainElement: ElementRef;\r\n\r\n  constructor() {\r\n    if (!this.onStarsCountChange) {\r\n      this.onStarsCountChange = new Subject();\r\n      this.onStarsCountChange.subscribe(() => {\r\n        this.setStars();\r\n        this.generateRating(true);\r\n        this.applySizeAllStars();\r\n        this.applyColorStyleAllStars(false);\r\n        this.addRemoveEvents();\r\n      });\r\n    }\r\n\r\n    if (!this.onValueChange) {\r\n      this.onValueChange = new Subject();\r\n      this.onValueChange.subscribe(() => {\r\n        this.generateRating();\r\n        this.applySizeAllStars();\r\n      });\r\n    }\r\n\r\n    if (!this.onCheckedColorChange) {\r\n      this.onCheckedColorChange = new Subject();\r\n      this.onCheckedColorChange.subscribe(() => {\r\n        this.applyColorStyleAllStars(true);\r\n      });\r\n    }\r\n\r\n    if (!this.onUnCheckedColorChange) {\r\n      this.onUnCheckedColorChange = new Subject();\r\n      this.onUnCheckedColorChange.subscribe(() => {\r\n        this.applyColorStyleAllStars(false);\r\n      });\r\n    }\r\n\r\n    if (!this.onSizeChange) {\r\n      this.onSizeChange = new Subject();\r\n      this.onSizeChange.subscribe(() => {\r\n        this.applySizeAllStars();\r\n      });\r\n    }\r\n\r\n    if (!this.onReadOnlyChange) {\r\n      this.onReadOnlyChange = new Subject();\r\n      this.onReadOnlyChange.subscribe(() => {\r\n        this.addRemoveEvents();\r\n      });\r\n    }\r\n  }\r\n\r\n  get checkedcolor(): string {\r\n    return this._checkedColor;\r\n  }\r\n\r\n  get uncheckedcolor(): string {\r\n    return this._unCheckedColor;\r\n  }\r\n\r\n  get value(): number {\r\n    return this._value;\r\n  }\r\n\r\n  get size(): string {\r\n    return this._size.concat((!this._size.includes(\"px\") ? \"px\" : \"\"));\r\n  }\r\n\r\n  get readonly(): boolean {\r\n    return String(this._readOnly) === \"true\";\r\n  }\r\n\r\n  get totalstars(): number {\r\n    return this._totalStars;\r\n  }\r\n\r\n  @Output() rate: EventEmitter<{ oldValue: number, newValue: number, starRating: StarRatingComponent }> = new EventEmitter();\r\n\r\n  @Input(StarRatingComponent.INP_CHECKED_COLOR) set checkedcolor(value: string) {\r\n    this._checkedColor = value;\r\n    this._checkedColor && this.onCheckedColorChange.next(this._checkedColor);\r\n  }\r\n\r\n  @Input(StarRatingComponent.INP_UNCHECKED_COLOR) set uncheckedcolor(value: string) {\r\n    this._unCheckedColor = value;\r\n    this._unCheckedColor && this.onUnCheckedColorChange.next(this._unCheckedColor);\r\n  }\r\n\r\n  @Input(StarRatingComponent.INP_VALUE) set value(value: number) {\r\n    value = (!value || value == null) ? 0 : value;\r\n    this._value = value;\r\n    this._value >= 0 && this.onValueChange.next(this._value);\r\n  }\r\n\r\n  @Input(StarRatingComponent.INP_SIZE) set size(value: string) {\r\n    value = (!value || value == null || value == \"0px\") ? \"24px\" : value;\r\n    this._size = value;\r\n    this.onSizeChange.next(this._size);\r\n  }\r\n\r\n  @Input(StarRatingComponent.INP_READONLY) set readonly(value: boolean) {\r\n    this._readOnly = value;\r\n    this.onReadOnlyChange.next(value);\r\n  }\r\n\r\n  @Input(StarRatingComponent.INP_TOTALSTARS) set totalstars(value: number) {\r\n    this._totalStars = value <= 0 ? 5 : value;\r\n    this.onStarsCountChange.next(Number(value));\r\n  }\r\n\r\n  private makeEditable() {\r\n    if (!this.mainElement) return;\r\n    this.mainElement.nativeElement.addEventListener('mouseleave', this.offStar.bind(this));\r\n    this.mainElement.nativeElement.style.cursor = \"pointer\";\r\n    this.mainElement.nativeElement.title = this.value;\r\n    this.stars.forEach((star: any) => {\r\n      star.addEventListener('click', this.onRate.bind(this));\r\n      star.addEventListener('mouseenter', this.onStar.bind(this));\r\n      star.style.cursor = \"pointer\";\r\n      star.title = star.dataset.index;\r\n    });\r\n  }\r\n\r\n  private makeReadOnly() {\r\n    if (!this.mainElement) return;\r\n    this.mainElement.nativeElement.style.cursor = \"default\";\r\n    this.mainElement.nativeElement.title = this.value;\r\n    this.stars.forEach((star: any) => {\r\n      star.style.cursor = \"default\";\r\n      star.title = \"\";\r\n    });\r\n  }\r\n\r\n  private addRemoveEvents() {\r\n    if (this.readonly) {\r\n      this.makeReadOnly();\r\n    } else {\r\n      this.makeEditable();\r\n      this.onValueChange.next(this.value);\r\n    }\r\n  }\r\n\r\n  private ngAfterViewInit() {\r\n  }\r\n\r\n  private onRate(event: MouseEvent) {\r\n    if (this.readonly) return;\r\n    let star: HTMLElement = <HTMLElement>event.srcElement;\r\n    let oldValue = this.value;\r\n    this.value = parseInt(star.dataset.index);\r\n    if (this.value == 0) {\r\n      this.value = 1;\r\n    }\r\n    let rateValues = { oldValue: oldValue, newValue: this.value, starRating: this };\r\n    this.rate.emit(rateValues);\r\n  }\r\n\r\n  private onStar(event: MouseEvent) {\r\n    if (this.readonly) return;\r\n    let star: HTMLElement = <HTMLElement>event.srcElement;\r\n    let currentIndex = parseInt(star.dataset.index);\r\n\r\n    for (let index = 0; index < currentIndex; index++) {\r\n      this.stars[index].className = \"\";\r\n      this.addDefaultClass(this.stars[index]);\r\n      this.addCheckedStarClass(this.stars[index]);\r\n    }\r\n\r\n    for (let index = currentIndex; index < this.stars.length; index++) {\r\n      this.stars[index].className = \"\";\r\n      this.addDefaultClass(this.stars[index]);\r\n    }\r\n  }\r\n\r\n  private offStar(event: MouseEvent) {\r\n    this.generateRating();\r\n  }\r\n\r\n  private addDefaultClass(star: any) {\r\n    star.classList.add(StarRatingComponent.CLS_DEFAULT_STAR);\r\n  }\r\n\r\n  private addCheckedStarClass(star: any) {\r\n    star.classList.add(StarRatingComponent.CLS_CHECKED_STAR);\r\n  }\r\n\r\n  private addHalfStarClass(star: any) {\r\n    star.classList.add(StarRatingComponent.CLS_HALF_STAR);\r\n  }\r\n\r\n  private setStars() {\r\n    if (!this.mainElement) return;\r\n    let starContainer: HTMLDivElement = this.mainElement.nativeElement;\r\n    let maxStars = [...Array(Number(this.totalstars)).keys()];\r\n    this.stars.length = 0;\r\n    starContainer.innerHTML = \"\";\r\n    maxStars.forEach(starNumber => {\r\n      let starElement: HTMLSpanElement = document.createElement(\"span\");\r\n      starElement.dataset.index = (starNumber + 1).toString();\r\n      starElement.title = starElement.dataset.index;\r\n      starContainer.appendChild(starElement);\r\n      this.stars.push(starElement);\r\n    });\r\n  }\r\n\r\n  private applySizeAllStars() {\r\n    if (this._size) {\r\n      this.stars.length == 0 && this.setStars();\r\n      this.stars.forEach((star: any) => {\r\n        // const newSize = this._size.match(/\\d+/)[0];\r\n        // let halfSize = parseInt(newSize, 10) / 2;\r\n        // let halfMargin = 0 - parseInt(newSize, 10);        \r\n        let newSize = this.size.match(/\\d+/)[0];\r\n        let halfSize = (parseInt(newSize) * 10) / 24;\r\n        let halfMargin = 0 - ((parseInt(newSize) * 20) / 24);\r\n        star.style.setProperty(StarRatingComponent.VAR_SIZE, this.size);\r\n        if (star.classList.contains(StarRatingComponent.CLS_HALF_STAR)) {\r\n          star.style.setProperty(StarRatingComponent.VAR_HALF_WIDTH, `${halfSize}px`);\r\n          star.style.setProperty(StarRatingComponent.VAR_HALF_MARGIN, `${halfMargin}px`);\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  private applyColorStyleAllStars(setChecked: boolean) {\r\n    this.stars.length == 0 && this.setStars();\r\n    this.stars.forEach((star: any) => {\r\n      if (setChecked) {\r\n        this.applyCheckedColorStyle(star);\r\n      } else {\r\n        this.applyUnCheckedColorStyle(star);\r\n      }\r\n    });\r\n  }\r\n\r\n  private applyColorStyle(starElement: HTMLSpanElement) {\r\n    this.applyCheckedColorStyle(starElement);\r\n    this.applyUnCheckedColorStyle(starElement);\r\n  }\r\n\r\n  private applyCheckedColorStyle(starElement: HTMLSpanElement) {\r\n    starElement.style.setProperty(StarRatingComponent.VAR_CHECKED_COLOR, this.checkedcolor);\r\n  }\r\n\r\n  private applyUnCheckedColorStyle(starElement: HTMLSpanElement) {\r\n    starElement.style.setProperty(StarRatingComponent.VAR_UNCHECKED_COLOR, this.uncheckedcolor);\r\n  }\r\n\r\n  private generateRating(forceGenerate:boolean = false) {\r\n    if (this.readonly && !forceGenerate) return;\r\n    if (!this.mainElement) return;\r\n    this.stars.length == 0 && this.setStars();\r\n    if (this.value >= 0) {\r\n      this.mainElement.nativeElement.title = this.value;\r\n\r\n      let hasDecimals: boolean =\r\n        ((Number.parseFloat(this.value.toString()) % 1)\r\n          .toString()\r\n          .substring(3, 2)) ? true : false;\r\n\r\n      let i = 1;\r\n      this.stars.forEach((star: any) => {\r\n        star.className = \"\";\r\n        this.applyColorStyle(star);\r\n        this.addDefaultClass(star);\r\n\r\n        if (this.value >= i) {\r\n          // star on\r\n          this.addCheckedStarClass(star);\r\n        } else {\r\n          // half star\r\n          if (hasDecimals) {\r\n            this.addHalfStarClass(star);\r\n            hasDecimals = false;\r\n          }\r\n        }\r\n        i++;\r\n      });\r\n    }\r\n  }\r\n}\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"star-rating.component.js","sourceRoot":"ng://ng-starrating/","sources":["components/star-rating/star-rating.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, ViewChild, ElementRef, \r\n  EventEmitter, ViewEncapsulation } from '@angular/core';\r\nimport { Subject } from 'rxjs';\r\n\r\n@Component({\r\n  selector: 'star-rating',\r\n  templateUrl: './star-rating.component.html',\r\n  styleUrls: ['./star-rating.component.css'],\r\n  encapsulation: ViewEncapsulation.ShadowDom\r\n})\r\n\r\nexport class StarRatingComponent {\r\n  private stars: Array<Element> = [];\r\n  \r\n  private _checkedColor: string;\r\n  private _unCheckedColor: string;\r\n  private _value: number;\r\n  private _size: string;\r\n  private _readOnly: boolean = false;\r\n\r\n  private _totalStars: number = 5;\r\n  private onStarsCountChange: Subject<number>;\r\n  private onValueChange: Subject<number>;\r\n  private onCheckedColorChange: Subject<string>;\r\n  private onUnCheckedColorChange: Subject<string>;\r\n  private onSizeChange: Subject<string>;\r\n  private onReadOnlyChange: Subject<boolean>;\r\n\r\n  private static readonly VAR_CHECKED_COLOR: string = '--checkedColor';\r\n  private static readonly VAR_UNCHECKED_COLOR: string = '--unCheckedColor';\r\n  private static readonly VAR_SIZE: string = '--size';\r\n  private static readonly VAR_HALF_WIDTH: string = '--halfWidth';\r\n  private static readonly VAR_HALF_MARGIN: string = '--halfMargin';\r\n  private static readonly CLS_CHECKED_STAR: string = 'on';\r\n  private static readonly CLS_DEFAULT_STAR: string = 'star';\r\n  private static readonly CLS_HALF_STAR: string = 'half';\r\n  private static readonly INP_CHECKED_COLOR: string = 'checkedcolor';\r\n  private static readonly INP_UNCHECKED_COLOR: string = 'uncheckedcolor';\r\n  private static readonly INP_VALUE: string = 'value';\r\n  private static readonly INP_SIZE: string = 'size';\r\n  private static readonly INP_READONLY: string = 'readonly';\r\n  private static readonly INP_TOTALSTARS: string = 'totalstars';\r\n\r\n  @ViewChild('starMain', { static: true }) private mainElement: ElementRef;\r\n\r\n  constructor() {\r\n    if (!this.onStarsCountChange) {\r\n      this.onStarsCountChange = new Subject();\r\n      this.onStarsCountChange.subscribe(() => {\r\n        this.setStars();\r\n        this.generateRating(true);\r\n        this.applySizeAllStars();\r\n        this.applyColorStyleAllStars(false);\r\n        this.addEvents();\r\n        //this.addRemoveEvents();\r\n      });\r\n    }\r\n\r\n    if (!this.onValueChange) {\r\n      this.onValueChange = new Subject();\r\n      this.onValueChange.subscribe(() => {\r\n        this.generateRating();\r\n        this.applySizeAllStars();\r\n      });\r\n    }\r\n\r\n    if (!this.onCheckedColorChange) {\r\n      this.onCheckedColorChange = new Subject();\r\n      this.onCheckedColorChange.subscribe(() => {\r\n        this.applyColorStyleAllStars(true);\r\n      });\r\n    }\r\n\r\n    if (!this.onUnCheckedColorChange) {\r\n      this.onUnCheckedColorChange = new Subject();\r\n      this.onUnCheckedColorChange.subscribe(() => {\r\n        this.applyColorStyleAllStars(false);\r\n      });\r\n    }\r\n\r\n    if (!this.onSizeChange) {\r\n      this.onSizeChange = new Subject();\r\n      this.onSizeChange.subscribe(() => {\r\n        this.applySizeAllStars();\r\n      });\r\n    }\r\n\r\n    if (!this.onReadOnlyChange) {\r\n      this.onReadOnlyChange = new Subject();\r\n      this.onReadOnlyChange.subscribe(() => {\r\n        this.readonly ? this.makeReadOnly() : this.makeEditable();\r\n        //this.addRemoveEvents();\r\n      });\r\n    }\r\n  }\r\n\r\n  get checkedcolor(): string {\r\n    return this._checkedColor;\r\n  }\r\n\r\n  get uncheckedcolor(): string {\r\n    return this._unCheckedColor;\r\n  }\r\n\r\n  get value(): number {\r\n    return this._value;\r\n  }\r\n\r\n  get size(): string {\r\n    return this._size.concat((!this._size.includes(\"px\") ? \"px\" : \"\"));\r\n  }\r\n\r\n  get readonly(): boolean {\r\n    return String(this._readOnly) === \"true\";\r\n  }\r\n\r\n  get totalstars(): number {\r\n    return this._totalStars;\r\n  }\r\n\r\n  @Output() rate: EventEmitter<{ oldValue: number, newValue: number, starRating: StarRatingComponent }> = new EventEmitter();\r\n\r\n  @Input(StarRatingComponent.INP_CHECKED_COLOR) set checkedcolor(value: string) {\r\n    this._checkedColor = value;\r\n    this._checkedColor && this.onCheckedColorChange.next(this._checkedColor);\r\n  }\r\n\r\n  @Input(StarRatingComponent.INP_UNCHECKED_COLOR) set uncheckedcolor(value: string) {\r\n    this._unCheckedColor = value;\r\n    this._unCheckedColor && this.onUnCheckedColorChange.next(this._unCheckedColor);\r\n  }\r\n\r\n  @Input(StarRatingComponent.INP_VALUE) set value(value: number) {\r\n    value = (!value || value == null) ? 0 : value;\r\n    this._value = value;\r\n    this._value >= 0 && this.onValueChange.next(this._value);\r\n  }\r\n\r\n  @Input(StarRatingComponent.INP_SIZE) set size(value: string) {\r\n    value = (!value || value == null || value == \"0px\") ? \"24px\" : value;\r\n    this._size = value;\r\n    this.onSizeChange.next(this._size);\r\n  }\r\n\r\n  @Input(StarRatingComponent.INP_READONLY) set readonly(value: boolean) {\r\n    this._readOnly = value;\r\n    this.onReadOnlyChange.next(value);\r\n  }\r\n\r\n  @Input(StarRatingComponent.INP_TOTALSTARS) set totalstars(value: number) {\r\n    this._totalStars = value <= 0 ? 5 : value;\r\n    this.onStarsCountChange.next(Number(value));\r\n  }\r\n\r\n  // private makeEditable() {\r\n  //   if (!this.mainElement) return;\r\n  //   this.mainElement.nativeElement.addEventListener('mouseleave', this.offStar.bind(this));\r\n  //   this.mainElement.nativeElement.style.cursor = \"pointer\";\r\n  //   this.mainElement.nativeElement.title = this.value;\r\n  //   this.stars.forEach((star: any) => {\r\n  //     star.addEventListener('click', this.onRate.bind(this));\r\n  //     star.addEventListener('mouseenter', this.onStar.bind(this));\r\n  //     star.style.cursor = \"pointer\";\r\n  //     star.title = star.dataset.index;\r\n  //   });\r\n  // }\r\n\r\n  private makeEditable() {\r\n    if (!this.mainElement) return;\r\n    this.mainElement.nativeElement.style.cursor = \"pointer\";\r\n    this.mainElement.nativeElement.title = this.value;\r\n    this.stars.forEach((star: any) => {\r\n      star.style.cursor = \"pointer\";\r\n      star.title = star.dataset.index;\r\n    });\r\n  }\r\n\r\n  private makeReadOnly() {\r\n    if (!this.mainElement) return;\r\n    this.mainElement.nativeElement.style.cursor = \"default\";\r\n    this.mainElement.nativeElement.title = this.value;\r\n    this.stars.forEach((star: any) => {\r\n      star.style.cursor = \"default\";\r\n      star.title = \"\";\r\n    });\r\n  }\r\n\r\n  // private addRemoveEvents() {\r\n  //   if (this.readonly) {\r\n  //     this.makeReadOnly();\r\n  //   } else {\r\n  //     this.makeEditable();\r\n  //     this.onValueChange.next(this.value);\r\n  //   }\r\n  // }\r\n\r\n  private addEvents() {\r\n    if (!this.mainElement) return;\r\n    this.mainElement.nativeElement.addEventListener('mouseleave', this.offStar.bind(this));\r\n    this.mainElement.nativeElement.style.cursor = \"pointer\";\r\n    this.mainElement.nativeElement.title = this.value;\r\n    this.stars.forEach((star: any) => {\r\n      star.addEventListener('click', this.onRate.bind(this));\r\n      star.addEventListener('mouseenter', this.onStar.bind(this));\r\n      star.style.cursor = \"pointer\";\r\n      star.title = star.dataset.index;\r\n    });\r\n  }\r\n\r\n\r\n  private ngAfterViewInit() {\r\n  }\r\n\r\n  private onRate(event: MouseEvent) {\r\n    if (this.readonly) return;\r\n    let star: HTMLElement = <HTMLElement>event.srcElement;\r\n    let oldValue = this.value;\r\n    this.value = parseInt(star.dataset.index);\r\n    if (this.value == 0) {\r\n      this.value = 1;\r\n    }\r\n    let rateValues = { oldValue: oldValue, newValue: this.value, starRating: this };\r\n    this.rate.emit(rateValues);\r\n  }\r\n\r\n  private onStar(event: MouseEvent) {\r\n    if (this.readonly) return;\r\n    let star: HTMLElement = <HTMLElement>event.srcElement;\r\n    let currentIndex = parseInt(star.dataset.index);\r\n\r\n    for (let index = 0; index < currentIndex; index++) {\r\n      this.stars[index].className = \"\";\r\n      this.addDefaultClass(this.stars[index]);\r\n      this.addCheckedStarClass(this.stars[index]);\r\n    }\r\n\r\n    for (let index = currentIndex; index < this.stars.length; index++) {\r\n      this.stars[index].className = \"\";\r\n      this.addDefaultClass(this.stars[index]);\r\n    }\r\n  }\r\n\r\n  private offStar(event: MouseEvent) {\r\n    this.generateRating();\r\n  }\r\n\r\n  private addDefaultClass(star: any) {\r\n    star.classList.add(StarRatingComponent.CLS_DEFAULT_STAR);\r\n  }\r\n\r\n  private addCheckedStarClass(star: any) {\r\n    star.classList.add(StarRatingComponent.CLS_CHECKED_STAR);\r\n  }\r\n\r\n  private addHalfStarClass(star: any) {\r\n    star.classList.add(StarRatingComponent.CLS_HALF_STAR);\r\n  }\r\n\r\n  private setStars() {\r\n    if (!this.mainElement) return;\r\n    let starContainer: HTMLDivElement = this.mainElement.nativeElement;\r\n    let maxStars = [...Array(Number(this.totalstars)).keys()];\r\n    this.stars.length = 0;\r\n    starContainer.innerHTML = \"\";\r\n    maxStars.forEach(starNumber => {\r\n      let starElement: HTMLSpanElement = document.createElement(\"span\");\r\n      starElement.dataset.index = (starNumber + 1).toString();\r\n      starElement.title = starElement.dataset.index;\r\n      starContainer.appendChild(starElement);\r\n      this.stars.push(starElement);\r\n    });\r\n  }\r\n\r\n  private applySizeAllStars() {\r\n    if (this._size) {\r\n      this.stars.length == 0 && this.setStars();\r\n      this.stars.forEach((star: any) => {\r\n        // const newSize = this._size.match(/\\d+/)[0];\r\n        // let halfSize = parseInt(newSize, 10) / 2;\r\n        // let halfMargin = 0 - parseInt(newSize, 10);        \r\n        let newSize = this.size.match(/\\d+/)[0];\r\n        let halfSize = (parseInt(newSize) * 10) / 24;\r\n        let halfMargin = 0 - ((parseInt(newSize) * 20) / 24);\r\n        star.style.setProperty(StarRatingComponent.VAR_SIZE, this.size);\r\n        if (star.classList.contains(StarRatingComponent.CLS_HALF_STAR)) {\r\n          star.style.setProperty(StarRatingComponent.VAR_HALF_WIDTH, `${halfSize}px`);\r\n          star.style.setProperty(StarRatingComponent.VAR_HALF_MARGIN, `${halfMargin}px`);\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  private applyColorStyleAllStars(setChecked: boolean) {\r\n    this.stars.length == 0 && this.setStars();\r\n    this.stars.forEach((star: any) => {\r\n      if (setChecked) {\r\n        this.applyCheckedColorStyle(star);\r\n      } else {\r\n        this.applyUnCheckedColorStyle(star);\r\n      }\r\n    });\r\n  }\r\n\r\n  private applyColorStyle(starElement: HTMLSpanElement) {\r\n    this.applyCheckedColorStyle(starElement);\r\n    this.applyUnCheckedColorStyle(starElement);\r\n  }\r\n\r\n  private applyCheckedColorStyle(starElement: HTMLSpanElement) {\r\n    starElement.style.setProperty(StarRatingComponent.VAR_CHECKED_COLOR, this.checkedcolor);\r\n  }\r\n\r\n  private applyUnCheckedColorStyle(starElement: HTMLSpanElement) {\r\n    starElement.style.setProperty(StarRatingComponent.VAR_UNCHECKED_COLOR, this.uncheckedcolor);\r\n  }\r\n\r\n  private generateRating(forceGenerate:boolean = false) {\r\n    if (this.readonly && !forceGenerate) return;\r\n    if (!this.mainElement) return;\r\n    this.stars.length == 0 && this.setStars();\r\n    if (this.value >= 0) {\r\n      this.mainElement.nativeElement.title = this.value;\r\n\r\n      let hasDecimals: boolean =\r\n        ((Number.parseFloat(this.value.toString()) % 1)\r\n          .toString()\r\n          .substring(3, 2)) ? true : false;\r\n\r\n      let i = 1;\r\n      this.stars.forEach((star: any) => {\r\n        star.className = \"\";\r\n        this.applyColorStyle(star);\r\n        this.addDefaultClass(star);\r\n\r\n        if (this.value >= i) {\r\n          // star on\r\n          this.addCheckedStarClass(star);\r\n        } else {\r\n          // half star\r\n          if (hasDecimals) {\r\n            this.addHalfStarClass(star);\r\n            hasDecimals = false;\r\n          }\r\n        }\r\n        i++;\r\n      });\r\n    }\r\n  }\r\n}\r\n"]}

@@ -18,3 +18,4 @@ import { __decorate, __metadata, __read, __spread } from "tslib";

_this.applyColorStyleAllStars(false);
_this.addRemoveEvents();
_this.addEvents();
//this.addRemoveEvents();
});

@@ -50,3 +51,4 @@ }

this.onReadOnlyChange.subscribe(function () {
_this.addRemoveEvents();
_this.readonly ? _this.makeReadOnly() : _this.makeEditable();
//this.addRemoveEvents();
});

@@ -124,12 +126,20 @@ }

});
// private makeEditable() {
// if (!this.mainElement) return;
// this.mainElement.nativeElement.addEventListener('mouseleave', this.offStar.bind(this));
// this.mainElement.nativeElement.style.cursor = "pointer";
// this.mainElement.nativeElement.title = this.value;
// this.stars.forEach((star: any) => {
// star.addEventListener('click', this.onRate.bind(this));
// star.addEventListener('mouseenter', this.onStar.bind(this));
// star.style.cursor = "pointer";
// star.title = star.dataset.index;
// });
// }
StarRatingComponent.prototype.makeEditable = function () {
var _this = this;
if (!this.mainElement)
return;
this.mainElement.nativeElement.addEventListener('mouseleave', this.offStar.bind(this));
this.mainElement.nativeElement.style.cursor = "pointer";
this.mainElement.nativeElement.title = this.value;
this.stars.forEach(function (star) {
star.addEventListener('click', _this.onRate.bind(_this));
star.addEventListener('mouseenter', _this.onStar.bind(_this));
star.style.cursor = "pointer";

@@ -149,10 +159,23 @@ star.title = star.dataset.index;

};
StarRatingComponent.prototype.addRemoveEvents = function () {
if (this.readonly) {
this.makeReadOnly();
}
else {
this.makeEditable();
this.onValueChange.next(this.value);
}
// private addRemoveEvents() {
// if (this.readonly) {
// this.makeReadOnly();
// } else {
// this.makeEditable();
// this.onValueChange.next(this.value);
// }
// }
StarRatingComponent.prototype.addEvents = function () {
var _this = this;
if (!this.mainElement)
return;
this.mainElement.nativeElement.addEventListener('mouseleave', this.offStar.bind(this));
this.mainElement.nativeElement.style.cursor = "pointer";
this.mainElement.nativeElement.title = this.value;
this.stars.forEach(function (star) {
star.addEventListener('click', _this.onRate.bind(_this));
star.addEventListener('mouseenter', _this.onStar.bind(_this));
star.style.cursor = "pointer";
star.title = star.dataset.index;
});
};

@@ -355,2 +378,2 @@ StarRatingComponent.prototype.ngAfterViewInit = function () {

export { StarRatingComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"star-rating.component.js","sourceRoot":"ng://ng-starrating/","sources":["components/star-rating/star-rating.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, ViewChild, ElementRef, \r\n  EventEmitter, ViewEncapsulation } from '@angular/core';\r\nimport { Subject } from 'rxjs';\r\n\r\n@Component({\r\n  selector: 'star-rating',\r\n  templateUrl: './star-rating.component.html',\r\n  styleUrls: ['./star-rating.component.css'],\r\n  encapsulation: ViewEncapsulation.ShadowDom\r\n})\r\n\r\nexport class StarRatingComponent {\r\n  private stars: Array<Element> = [];\r\n  \r\n  private _checkedColor: string;\r\n  private _unCheckedColor: string;\r\n  private _value: number;\r\n  private _size: string;\r\n  private _readOnly: boolean = false;\r\n\r\n  private _totalStars: number = 5;\r\n  private onStarsCountChange: Subject<number>;\r\n  private onValueChange: Subject<number>;\r\n  private onCheckedColorChange: Subject<string>;\r\n  private onUnCheckedColorChange: Subject<string>;\r\n  private onSizeChange: Subject<string>;\r\n  private onReadOnlyChange: Subject<boolean>;\r\n\r\n  private static readonly VAR_CHECKED_COLOR: string = '--checkedColor';\r\n  private static readonly VAR_UNCHECKED_COLOR: string = '--unCheckedColor';\r\n  private static readonly VAR_SIZE: string = '--size';\r\n  private static readonly VAR_HALF_WIDTH: string = '--halfWidth';\r\n  private static readonly VAR_HALF_MARGIN: string = '--halfMargin';\r\n  private static readonly CLS_CHECKED_STAR: string = 'on';\r\n  private static readonly CLS_DEFAULT_STAR: string = 'star';\r\n  private static readonly CLS_HALF_STAR: string = 'half';\r\n  private static readonly INP_CHECKED_COLOR: string = 'checkedcolor';\r\n  private static readonly INP_UNCHECKED_COLOR: string = 'uncheckedcolor';\r\n  private static readonly INP_VALUE: string = 'value';\r\n  private static readonly INP_SIZE: string = 'size';\r\n  private static readonly INP_READONLY: string = 'readonly';\r\n  private static readonly INP_TOTALSTARS: string = 'totalstars';\r\n\r\n  @ViewChild('starMain', { static: true }) private mainElement: ElementRef;\r\n\r\n  constructor() {\r\n    if (!this.onStarsCountChange) {\r\n      this.onStarsCountChange = new Subject();\r\n      this.onStarsCountChange.subscribe(() => {\r\n        this.setStars();\r\n        this.generateRating(true);\r\n        this.applySizeAllStars();\r\n        this.applyColorStyleAllStars(false);\r\n        this.addRemoveEvents();\r\n      });\r\n    }\r\n\r\n    if (!this.onValueChange) {\r\n      this.onValueChange = new Subject();\r\n      this.onValueChange.subscribe(() => {\r\n        this.generateRating();\r\n        this.applySizeAllStars();\r\n      });\r\n    }\r\n\r\n    if (!this.onCheckedColorChange) {\r\n      this.onCheckedColorChange = new Subject();\r\n      this.onCheckedColorChange.subscribe(() => {\r\n        this.applyColorStyleAllStars(true);\r\n      });\r\n    }\r\n\r\n    if (!this.onUnCheckedColorChange) {\r\n      this.onUnCheckedColorChange = new Subject();\r\n      this.onUnCheckedColorChange.subscribe(() => {\r\n        this.applyColorStyleAllStars(false);\r\n      });\r\n    }\r\n\r\n    if (!this.onSizeChange) {\r\n      this.onSizeChange = new Subject();\r\n      this.onSizeChange.subscribe(() => {\r\n        this.applySizeAllStars();\r\n      });\r\n    }\r\n\r\n    if (!this.onReadOnlyChange) {\r\n      this.onReadOnlyChange = new Subject();\r\n      this.onReadOnlyChange.subscribe(() => {\r\n        this.addRemoveEvents();\r\n      });\r\n    }\r\n  }\r\n\r\n  get checkedcolor(): string {\r\n    return this._checkedColor;\r\n  }\r\n\r\n  get uncheckedcolor(): string {\r\n    return this._unCheckedColor;\r\n  }\r\n\r\n  get value(): number {\r\n    return this._value;\r\n  }\r\n\r\n  get size(): string {\r\n    return this._size.concat((!this._size.includes(\"px\") ? \"px\" : \"\"));\r\n  }\r\n\r\n  get readonly(): boolean {\r\n    return String(this._readOnly) === \"true\";\r\n  }\r\n\r\n  get totalstars(): number {\r\n    return this._totalStars;\r\n  }\r\n\r\n  @Output() rate: EventEmitter<{ oldValue: number, newValue: number, starRating: StarRatingComponent }> = new EventEmitter();\r\n\r\n  @Input(StarRatingComponent.INP_CHECKED_COLOR) set checkedcolor(value: string) {\r\n    this._checkedColor = value;\r\n    this._checkedColor && this.onCheckedColorChange.next(this._checkedColor);\r\n  }\r\n\r\n  @Input(StarRatingComponent.INP_UNCHECKED_COLOR) set uncheckedcolor(value: string) {\r\n    this._unCheckedColor = value;\r\n    this._unCheckedColor && this.onUnCheckedColorChange.next(this._unCheckedColor);\r\n  }\r\n\r\n  @Input(StarRatingComponent.INP_VALUE) set value(value: number) {\r\n    value = (!value || value == null) ? 0 : value;\r\n    this._value = value;\r\n    this._value >= 0 && this.onValueChange.next(this._value);\r\n  }\r\n\r\n  @Input(StarRatingComponent.INP_SIZE) set size(value: string) {\r\n    value = (!value || value == null || value == \"0px\") ? \"24px\" : value;\r\n    this._size = value;\r\n    this.onSizeChange.next(this._size);\r\n  }\r\n\r\n  @Input(StarRatingComponent.INP_READONLY) set readonly(value: boolean) {\r\n    this._readOnly = value;\r\n    this.onReadOnlyChange.next(value);\r\n  }\r\n\r\n  @Input(StarRatingComponent.INP_TOTALSTARS) set totalstars(value: number) {\r\n    this._totalStars = value <= 0 ? 5 : value;\r\n    this.onStarsCountChange.next(Number(value));\r\n  }\r\n\r\n  private makeEditable() {\r\n    if (!this.mainElement) return;\r\n    this.mainElement.nativeElement.addEventListener('mouseleave', this.offStar.bind(this));\r\n    this.mainElement.nativeElement.style.cursor = \"pointer\";\r\n    this.mainElement.nativeElement.title = this.value;\r\n    this.stars.forEach((star: any) => {\r\n      star.addEventListener('click', this.onRate.bind(this));\r\n      star.addEventListener('mouseenter', this.onStar.bind(this));\r\n      star.style.cursor = \"pointer\";\r\n      star.title = star.dataset.index;\r\n    });\r\n  }\r\n\r\n  private makeReadOnly() {\r\n    if (!this.mainElement) return;\r\n    this.mainElement.nativeElement.style.cursor = \"default\";\r\n    this.mainElement.nativeElement.title = this.value;\r\n    this.stars.forEach((star: any) => {\r\n      star.style.cursor = \"default\";\r\n      star.title = \"\";\r\n    });\r\n  }\r\n\r\n  private addRemoveEvents() {\r\n    if (this.readonly) {\r\n      this.makeReadOnly();\r\n    } else {\r\n      this.makeEditable();\r\n      this.onValueChange.next(this.value);\r\n    }\r\n  }\r\n\r\n  private ngAfterViewInit() {\r\n  }\r\n\r\n  private onRate(event: MouseEvent) {\r\n    if (this.readonly) return;\r\n    let star: HTMLElement = <HTMLElement>event.srcElement;\r\n    let oldValue = this.value;\r\n    this.value = parseInt(star.dataset.index);\r\n    if (this.value == 0) {\r\n      this.value = 1;\r\n    }\r\n    let rateValues = { oldValue: oldValue, newValue: this.value, starRating: this };\r\n    this.rate.emit(rateValues);\r\n  }\r\n\r\n  private onStar(event: MouseEvent) {\r\n    if (this.readonly) return;\r\n    let star: HTMLElement = <HTMLElement>event.srcElement;\r\n    let currentIndex = parseInt(star.dataset.index);\r\n\r\n    for (let index = 0; index < currentIndex; index++) {\r\n      this.stars[index].className = \"\";\r\n      this.addDefaultClass(this.stars[index]);\r\n      this.addCheckedStarClass(this.stars[index]);\r\n    }\r\n\r\n    for (let index = currentIndex; index < this.stars.length; index++) {\r\n      this.stars[index].className = \"\";\r\n      this.addDefaultClass(this.stars[index]);\r\n    }\r\n  }\r\n\r\n  private offStar(event: MouseEvent) {\r\n    this.generateRating();\r\n  }\r\n\r\n  private addDefaultClass(star: any) {\r\n    star.classList.add(StarRatingComponent.CLS_DEFAULT_STAR);\r\n  }\r\n\r\n  private addCheckedStarClass(star: any) {\r\n    star.classList.add(StarRatingComponent.CLS_CHECKED_STAR);\r\n  }\r\n\r\n  private addHalfStarClass(star: any) {\r\n    star.classList.add(StarRatingComponent.CLS_HALF_STAR);\r\n  }\r\n\r\n  private setStars() {\r\n    if (!this.mainElement) return;\r\n    let starContainer: HTMLDivElement = this.mainElement.nativeElement;\r\n    let maxStars = [...Array(Number(this.totalstars)).keys()];\r\n    this.stars.length = 0;\r\n    starContainer.innerHTML = \"\";\r\n    maxStars.forEach(starNumber => {\r\n      let starElement: HTMLSpanElement = document.createElement(\"span\");\r\n      starElement.dataset.index = (starNumber + 1).toString();\r\n      starElement.title = starElement.dataset.index;\r\n      starContainer.appendChild(starElement);\r\n      this.stars.push(starElement);\r\n    });\r\n  }\r\n\r\n  private applySizeAllStars() {\r\n    if (this._size) {\r\n      this.stars.length == 0 && this.setStars();\r\n      this.stars.forEach((star: any) => {\r\n        // const newSize = this._size.match(/\\d+/)[0];\r\n        // let halfSize = parseInt(newSize, 10) / 2;\r\n        // let halfMargin = 0 - parseInt(newSize, 10);        \r\n        let newSize = this.size.match(/\\d+/)[0];\r\n        let halfSize = (parseInt(newSize) * 10) / 24;\r\n        let halfMargin = 0 - ((parseInt(newSize) * 20) / 24);\r\n        star.style.setProperty(StarRatingComponent.VAR_SIZE, this.size);\r\n        if (star.classList.contains(StarRatingComponent.CLS_HALF_STAR)) {\r\n          star.style.setProperty(StarRatingComponent.VAR_HALF_WIDTH, `${halfSize}px`);\r\n          star.style.setProperty(StarRatingComponent.VAR_HALF_MARGIN, `${halfMargin}px`);\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  private applyColorStyleAllStars(setChecked: boolean) {\r\n    this.stars.length == 0 && this.setStars();\r\n    this.stars.forEach((star: any) => {\r\n      if (setChecked) {\r\n        this.applyCheckedColorStyle(star);\r\n      } else {\r\n        this.applyUnCheckedColorStyle(star);\r\n      }\r\n    });\r\n  }\r\n\r\n  private applyColorStyle(starElement: HTMLSpanElement) {\r\n    this.applyCheckedColorStyle(starElement);\r\n    this.applyUnCheckedColorStyle(starElement);\r\n  }\r\n\r\n  private applyCheckedColorStyle(starElement: HTMLSpanElement) {\r\n    starElement.style.setProperty(StarRatingComponent.VAR_CHECKED_COLOR, this.checkedcolor);\r\n  }\r\n\r\n  private applyUnCheckedColorStyle(starElement: HTMLSpanElement) {\r\n    starElement.style.setProperty(StarRatingComponent.VAR_UNCHECKED_COLOR, this.uncheckedcolor);\r\n  }\r\n\r\n  private generateRating(forceGenerate:boolean = false) {\r\n    if (this.readonly && !forceGenerate) return;\r\n    if (!this.mainElement) return;\r\n    this.stars.length == 0 && this.setStars();\r\n    if (this.value >= 0) {\r\n      this.mainElement.nativeElement.title = this.value;\r\n\r\n      let hasDecimals: boolean =\r\n        ((Number.parseFloat(this.value.toString()) % 1)\r\n          .toString()\r\n          .substring(3, 2)) ? true : false;\r\n\r\n      let i = 1;\r\n      this.stars.forEach((star: any) => {\r\n        star.className = \"\";\r\n        this.applyColorStyle(star);\r\n        this.addDefaultClass(star);\r\n\r\n        if (this.value >= i) {\r\n          // star on\r\n          this.addCheckedStarClass(star);\r\n        } else {\r\n          // half star\r\n          if (hasDecimals) {\r\n            this.addHalfStarClass(star);\r\n            hasDecimals = false;\r\n          }\r\n        }\r\n        i++;\r\n      });\r\n    }\r\n  }\r\n}\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"star-rating.component.js","sourceRoot":"ng://ng-starrating/","sources":["components/star-rating/star-rating.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, ViewChild, ElementRef, \r\n  EventEmitter, ViewEncapsulation } from '@angular/core';\r\nimport { Subject } from 'rxjs';\r\n\r\n@Component({\r\n  selector: 'star-rating',\r\n  templateUrl: './star-rating.component.html',\r\n  styleUrls: ['./star-rating.component.css'],\r\n  encapsulation: ViewEncapsulation.ShadowDom\r\n})\r\n\r\nexport class StarRatingComponent {\r\n  private stars: Array<Element> = [];\r\n  \r\n  private _checkedColor: string;\r\n  private _unCheckedColor: string;\r\n  private _value: number;\r\n  private _size: string;\r\n  private _readOnly: boolean = false;\r\n\r\n  private _totalStars: number = 5;\r\n  private onStarsCountChange: Subject<number>;\r\n  private onValueChange: Subject<number>;\r\n  private onCheckedColorChange: Subject<string>;\r\n  private onUnCheckedColorChange: Subject<string>;\r\n  private onSizeChange: Subject<string>;\r\n  private onReadOnlyChange: Subject<boolean>;\r\n\r\n  private static readonly VAR_CHECKED_COLOR: string = '--checkedColor';\r\n  private static readonly VAR_UNCHECKED_COLOR: string = '--unCheckedColor';\r\n  private static readonly VAR_SIZE: string = '--size';\r\n  private static readonly VAR_HALF_WIDTH: string = '--halfWidth';\r\n  private static readonly VAR_HALF_MARGIN: string = '--halfMargin';\r\n  private static readonly CLS_CHECKED_STAR: string = 'on';\r\n  private static readonly CLS_DEFAULT_STAR: string = 'star';\r\n  private static readonly CLS_HALF_STAR: string = 'half';\r\n  private static readonly INP_CHECKED_COLOR: string = 'checkedcolor';\r\n  private static readonly INP_UNCHECKED_COLOR: string = 'uncheckedcolor';\r\n  private static readonly INP_VALUE: string = 'value';\r\n  private static readonly INP_SIZE: string = 'size';\r\n  private static readonly INP_READONLY: string = 'readonly';\r\n  private static readonly INP_TOTALSTARS: string = 'totalstars';\r\n\r\n  @ViewChild('starMain', { static: true }) private mainElement: ElementRef;\r\n\r\n  constructor() {\r\n    if (!this.onStarsCountChange) {\r\n      this.onStarsCountChange = new Subject();\r\n      this.onStarsCountChange.subscribe(() => {\r\n        this.setStars();\r\n        this.generateRating(true);\r\n        this.applySizeAllStars();\r\n        this.applyColorStyleAllStars(false);\r\n        this.addEvents();\r\n        //this.addRemoveEvents();\r\n      });\r\n    }\r\n\r\n    if (!this.onValueChange) {\r\n      this.onValueChange = new Subject();\r\n      this.onValueChange.subscribe(() => {\r\n        this.generateRating();\r\n        this.applySizeAllStars();\r\n      });\r\n    }\r\n\r\n    if (!this.onCheckedColorChange) {\r\n      this.onCheckedColorChange = new Subject();\r\n      this.onCheckedColorChange.subscribe(() => {\r\n        this.applyColorStyleAllStars(true);\r\n      });\r\n    }\r\n\r\n    if (!this.onUnCheckedColorChange) {\r\n      this.onUnCheckedColorChange = new Subject();\r\n      this.onUnCheckedColorChange.subscribe(() => {\r\n        this.applyColorStyleAllStars(false);\r\n      });\r\n    }\r\n\r\n    if (!this.onSizeChange) {\r\n      this.onSizeChange = new Subject();\r\n      this.onSizeChange.subscribe(() => {\r\n        this.applySizeAllStars();\r\n      });\r\n    }\r\n\r\n    if (!this.onReadOnlyChange) {\r\n      this.onReadOnlyChange = new Subject();\r\n      this.onReadOnlyChange.subscribe(() => {\r\n        this.readonly ? this.makeReadOnly() : this.makeEditable();\r\n        //this.addRemoveEvents();\r\n      });\r\n    }\r\n  }\r\n\r\n  get checkedcolor(): string {\r\n    return this._checkedColor;\r\n  }\r\n\r\n  get uncheckedcolor(): string {\r\n    return this._unCheckedColor;\r\n  }\r\n\r\n  get value(): number {\r\n    return this._value;\r\n  }\r\n\r\n  get size(): string {\r\n    return this._size.concat((!this._size.includes(\"px\") ? \"px\" : \"\"));\r\n  }\r\n\r\n  get readonly(): boolean {\r\n    return String(this._readOnly) === \"true\";\r\n  }\r\n\r\n  get totalstars(): number {\r\n    return this._totalStars;\r\n  }\r\n\r\n  @Output() rate: EventEmitter<{ oldValue: number, newValue: number, starRating: StarRatingComponent }> = new EventEmitter();\r\n\r\n  @Input(StarRatingComponent.INP_CHECKED_COLOR) set checkedcolor(value: string) {\r\n    this._checkedColor = value;\r\n    this._checkedColor && this.onCheckedColorChange.next(this._checkedColor);\r\n  }\r\n\r\n  @Input(StarRatingComponent.INP_UNCHECKED_COLOR) set uncheckedcolor(value: string) {\r\n    this._unCheckedColor = value;\r\n    this._unCheckedColor && this.onUnCheckedColorChange.next(this._unCheckedColor);\r\n  }\r\n\r\n  @Input(StarRatingComponent.INP_VALUE) set value(value: number) {\r\n    value = (!value || value == null) ? 0 : value;\r\n    this._value = value;\r\n    this._value >= 0 && this.onValueChange.next(this._value);\r\n  }\r\n\r\n  @Input(StarRatingComponent.INP_SIZE) set size(value: string) {\r\n    value = (!value || value == null || value == \"0px\") ? \"24px\" : value;\r\n    this._size = value;\r\n    this.onSizeChange.next(this._size);\r\n  }\r\n\r\n  @Input(StarRatingComponent.INP_READONLY) set readonly(value: boolean) {\r\n    this._readOnly = value;\r\n    this.onReadOnlyChange.next(value);\r\n  }\r\n\r\n  @Input(StarRatingComponent.INP_TOTALSTARS) set totalstars(value: number) {\r\n    this._totalStars = value <= 0 ? 5 : value;\r\n    this.onStarsCountChange.next(Number(value));\r\n  }\r\n\r\n  // private makeEditable() {\r\n  //   if (!this.mainElement) return;\r\n  //   this.mainElement.nativeElement.addEventListener('mouseleave', this.offStar.bind(this));\r\n  //   this.mainElement.nativeElement.style.cursor = \"pointer\";\r\n  //   this.mainElement.nativeElement.title = this.value;\r\n  //   this.stars.forEach((star: any) => {\r\n  //     star.addEventListener('click', this.onRate.bind(this));\r\n  //     star.addEventListener('mouseenter', this.onStar.bind(this));\r\n  //     star.style.cursor = \"pointer\";\r\n  //     star.title = star.dataset.index;\r\n  //   });\r\n  // }\r\n\r\n  private makeEditable() {\r\n    if (!this.mainElement) return;\r\n    this.mainElement.nativeElement.style.cursor = \"pointer\";\r\n    this.mainElement.nativeElement.title = this.value;\r\n    this.stars.forEach((star: any) => {\r\n      star.style.cursor = \"pointer\";\r\n      star.title = star.dataset.index;\r\n    });\r\n  }\r\n\r\n  private makeReadOnly() {\r\n    if (!this.mainElement) return;\r\n    this.mainElement.nativeElement.style.cursor = \"default\";\r\n    this.mainElement.nativeElement.title = this.value;\r\n    this.stars.forEach((star: any) => {\r\n      star.style.cursor = \"default\";\r\n      star.title = \"\";\r\n    });\r\n  }\r\n\r\n  // private addRemoveEvents() {\r\n  //   if (this.readonly) {\r\n  //     this.makeReadOnly();\r\n  //   } else {\r\n  //     this.makeEditable();\r\n  //     this.onValueChange.next(this.value);\r\n  //   }\r\n  // }\r\n\r\n  private addEvents() {\r\n    if (!this.mainElement) return;\r\n    this.mainElement.nativeElement.addEventListener('mouseleave', this.offStar.bind(this));\r\n    this.mainElement.nativeElement.style.cursor = \"pointer\";\r\n    this.mainElement.nativeElement.title = this.value;\r\n    this.stars.forEach((star: any) => {\r\n      star.addEventListener('click', this.onRate.bind(this));\r\n      star.addEventListener('mouseenter', this.onStar.bind(this));\r\n      star.style.cursor = \"pointer\";\r\n      star.title = star.dataset.index;\r\n    });\r\n  }\r\n\r\n\r\n  private ngAfterViewInit() {\r\n  }\r\n\r\n  private onRate(event: MouseEvent) {\r\n    if (this.readonly) return;\r\n    let star: HTMLElement = <HTMLElement>event.srcElement;\r\n    let oldValue = this.value;\r\n    this.value = parseInt(star.dataset.index);\r\n    if (this.value == 0) {\r\n      this.value = 1;\r\n    }\r\n    let rateValues = { oldValue: oldValue, newValue: this.value, starRating: this };\r\n    this.rate.emit(rateValues);\r\n  }\r\n\r\n  private onStar(event: MouseEvent) {\r\n    if (this.readonly) return;\r\n    let star: HTMLElement = <HTMLElement>event.srcElement;\r\n    let currentIndex = parseInt(star.dataset.index);\r\n\r\n    for (let index = 0; index < currentIndex; index++) {\r\n      this.stars[index].className = \"\";\r\n      this.addDefaultClass(this.stars[index]);\r\n      this.addCheckedStarClass(this.stars[index]);\r\n    }\r\n\r\n    for (let index = currentIndex; index < this.stars.length; index++) {\r\n      this.stars[index].className = \"\";\r\n      this.addDefaultClass(this.stars[index]);\r\n    }\r\n  }\r\n\r\n  private offStar(event: MouseEvent) {\r\n    this.generateRating();\r\n  }\r\n\r\n  private addDefaultClass(star: any) {\r\n    star.classList.add(StarRatingComponent.CLS_DEFAULT_STAR);\r\n  }\r\n\r\n  private addCheckedStarClass(star: any) {\r\n    star.classList.add(StarRatingComponent.CLS_CHECKED_STAR);\r\n  }\r\n\r\n  private addHalfStarClass(star: any) {\r\n    star.classList.add(StarRatingComponent.CLS_HALF_STAR);\r\n  }\r\n\r\n  private setStars() {\r\n    if (!this.mainElement) return;\r\n    let starContainer: HTMLDivElement = this.mainElement.nativeElement;\r\n    let maxStars = [...Array(Number(this.totalstars)).keys()];\r\n    this.stars.length = 0;\r\n    starContainer.innerHTML = \"\";\r\n    maxStars.forEach(starNumber => {\r\n      let starElement: HTMLSpanElement = document.createElement(\"span\");\r\n      starElement.dataset.index = (starNumber + 1).toString();\r\n      starElement.title = starElement.dataset.index;\r\n      starContainer.appendChild(starElement);\r\n      this.stars.push(starElement);\r\n    });\r\n  }\r\n\r\n  private applySizeAllStars() {\r\n    if (this._size) {\r\n      this.stars.length == 0 && this.setStars();\r\n      this.stars.forEach((star: any) => {\r\n        // const newSize = this._size.match(/\\d+/)[0];\r\n        // let halfSize = parseInt(newSize, 10) / 2;\r\n        // let halfMargin = 0 - parseInt(newSize, 10);        \r\n        let newSize = this.size.match(/\\d+/)[0];\r\n        let halfSize = (parseInt(newSize) * 10) / 24;\r\n        let halfMargin = 0 - ((parseInt(newSize) * 20) / 24);\r\n        star.style.setProperty(StarRatingComponent.VAR_SIZE, this.size);\r\n        if (star.classList.contains(StarRatingComponent.CLS_HALF_STAR)) {\r\n          star.style.setProperty(StarRatingComponent.VAR_HALF_WIDTH, `${halfSize}px`);\r\n          star.style.setProperty(StarRatingComponent.VAR_HALF_MARGIN, `${halfMargin}px`);\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  private applyColorStyleAllStars(setChecked: boolean) {\r\n    this.stars.length == 0 && this.setStars();\r\n    this.stars.forEach((star: any) => {\r\n      if (setChecked) {\r\n        this.applyCheckedColorStyle(star);\r\n      } else {\r\n        this.applyUnCheckedColorStyle(star);\r\n      }\r\n    });\r\n  }\r\n\r\n  private applyColorStyle(starElement: HTMLSpanElement) {\r\n    this.applyCheckedColorStyle(starElement);\r\n    this.applyUnCheckedColorStyle(starElement);\r\n  }\r\n\r\n  private applyCheckedColorStyle(starElement: HTMLSpanElement) {\r\n    starElement.style.setProperty(StarRatingComponent.VAR_CHECKED_COLOR, this.checkedcolor);\r\n  }\r\n\r\n  private applyUnCheckedColorStyle(starElement: HTMLSpanElement) {\r\n    starElement.style.setProperty(StarRatingComponent.VAR_UNCHECKED_COLOR, this.uncheckedcolor);\r\n  }\r\n\r\n  private generateRating(forceGenerate:boolean = false) {\r\n    if (this.readonly && !forceGenerate) return;\r\n    if (!this.mainElement) return;\r\n    this.stars.length == 0 && this.setStars();\r\n    if (this.value >= 0) {\r\n      this.mainElement.nativeElement.title = this.value;\r\n\r\n      let hasDecimals: boolean =\r\n        ((Number.parseFloat(this.value.toString()) % 1)\r\n          .toString()\r\n          .substring(3, 2)) ? true : false;\r\n\r\n      let i = 1;\r\n      this.stars.forEach((star: any) => {\r\n        star.className = \"\";\r\n        this.applyColorStyle(star);\r\n        this.addDefaultClass(star);\r\n\r\n        if (this.value >= i) {\r\n          // star on\r\n          this.addCheckedStarClass(star);\r\n        } else {\r\n          // half star\r\n          if (hasDecimals) {\r\n            this.addHalfStarClass(star);\r\n            hasDecimals = false;\r\n          }\r\n        }\r\n        i++;\r\n      });\r\n    }\r\n  }\r\n}\r\n"]}

@@ -38,3 +38,4 @@ import { __decorate, __metadata } from 'tslib';

this.applyColorStyleAllStars(false);
this.addRemoveEvents();
this.addEvents();
//this.addRemoveEvents();
});

@@ -70,3 +71,4 @@ }

this.onReadOnlyChange.subscribe(() => {
this.addRemoveEvents();
this.readonly ? this.makeReadOnly() : this.makeEditable();
//this.addRemoveEvents();
});

@@ -119,11 +121,20 @@ }

}
// private makeEditable() {
// if (!this.mainElement) return;
// this.mainElement.nativeElement.addEventListener('mouseleave', this.offStar.bind(this));
// this.mainElement.nativeElement.style.cursor = "pointer";
// this.mainElement.nativeElement.title = this.value;
// this.stars.forEach((star: any) => {
// star.addEventListener('click', this.onRate.bind(this));
// star.addEventListener('mouseenter', this.onStar.bind(this));
// star.style.cursor = "pointer";
// star.title = star.dataset.index;
// });
// }
makeEditable() {
if (!this.mainElement)
return;
this.mainElement.nativeElement.addEventListener('mouseleave', this.offStar.bind(this));
this.mainElement.nativeElement.style.cursor = "pointer";
this.mainElement.nativeElement.title = this.value;
this.stars.forEach((star) => {
star.addEventListener('click', this.onRate.bind(this));
star.addEventListener('mouseenter', this.onStar.bind(this));
star.style.cursor = "pointer";

@@ -143,10 +154,22 @@ star.title = star.dataset.index;

}
addRemoveEvents() {
if (this.readonly) {
this.makeReadOnly();
}
else {
this.makeEditable();
this.onValueChange.next(this.value);
}
// private addRemoveEvents() {
// if (this.readonly) {
// this.makeReadOnly();
// } else {
// this.makeEditable();
// this.onValueChange.next(this.value);
// }
// }
addEvents() {
if (!this.mainElement)
return;
this.mainElement.nativeElement.addEventListener('mouseleave', this.offStar.bind(this));
this.mainElement.nativeElement.style.cursor = "pointer";
this.mainElement.nativeElement.title = this.value;
this.stars.forEach((star) => {
star.addEventListener('click', this.onRate.bind(this));
star.addEventListener('mouseenter', this.onStar.bind(this));
star.style.cursor = "pointer";
star.title = star.dataset.index;
});
}

@@ -153,0 +176,0 @@ ngAfterViewInit() {

@@ -36,3 +36,4 @@ import { __decorate, __metadata, __spread } from 'tslib';

_this.applyColorStyleAllStars(false);
_this.addRemoveEvents();
_this.addEvents();
//this.addRemoveEvents();
});

@@ -68,3 +69,4 @@ }

this.onReadOnlyChange.subscribe(function () {
_this.addRemoveEvents();
_this.readonly ? _this.makeReadOnly() : _this.makeEditable();
//this.addRemoveEvents();
});

@@ -142,12 +144,20 @@ }

});
// private makeEditable() {
// if (!this.mainElement) return;
// this.mainElement.nativeElement.addEventListener('mouseleave', this.offStar.bind(this));
// this.mainElement.nativeElement.style.cursor = "pointer";
// this.mainElement.nativeElement.title = this.value;
// this.stars.forEach((star: any) => {
// star.addEventListener('click', this.onRate.bind(this));
// star.addEventListener('mouseenter', this.onStar.bind(this));
// star.style.cursor = "pointer";
// star.title = star.dataset.index;
// });
// }
StarRatingComponent.prototype.makeEditable = function () {
var _this = this;
if (!this.mainElement)
return;
this.mainElement.nativeElement.addEventListener('mouseleave', this.offStar.bind(this));
this.mainElement.nativeElement.style.cursor = "pointer";
this.mainElement.nativeElement.title = this.value;
this.stars.forEach(function (star) {
star.addEventListener('click', _this.onRate.bind(_this));
star.addEventListener('mouseenter', _this.onStar.bind(_this));
star.style.cursor = "pointer";

@@ -167,10 +177,23 @@ star.title = star.dataset.index;

};
StarRatingComponent.prototype.addRemoveEvents = function () {
if (this.readonly) {
this.makeReadOnly();
}
else {
this.makeEditable();
this.onValueChange.next(this.value);
}
// private addRemoveEvents() {
// if (this.readonly) {
// this.makeReadOnly();
// } else {
// this.makeEditable();
// this.onValueChange.next(this.value);
// }
// }
StarRatingComponent.prototype.addEvents = function () {
var _this = this;
if (!this.mainElement)
return;
this.mainElement.nativeElement.addEventListener('mouseleave', this.offStar.bind(this));
this.mainElement.nativeElement.style.cursor = "pointer";
this.mainElement.nativeElement.title = this.value;
this.stars.forEach(function (star) {
star.addEventListener('click', _this.onRate.bind(_this));
star.addEventListener('mouseenter', _this.onStar.bind(_this));
star.style.cursor = "pointer";
star.title = star.dataset.index;
});
};

@@ -177,0 +200,0 @@ StarRatingComponent.prototype.ngAfterViewInit = function () {

@@ -1,1 +0,1 @@

{"__symbolic":"module","version":4,"metadata":{"RatingModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":6,"character":1},"arguments":[{"imports":[{"__symbolic":"reference","module":"@angular/forms","name":"FormsModule","line":8,"character":4},{"__symbolic":"reference","module":"@angular/common","name":"CommonModule","line":9,"character":4}],"declarations":[{"__symbolic":"reference","name":"ɵa"},{"__symbolic":"reference","name":"StarRatingComponent"}],"exports":[{"__symbolic":"reference","name":"StarRatingComponent"}],"entryComponents":[{"__symbolic":"reference","name":"StarRatingComponent"}]}]}],"members":{"ngDoBootstrap":[{"__symbolic":"method"}]}},"StarRatingComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":4,"character":1},"arguments":[{"selector":"star-rating","encapsulation":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewEncapsulation","line":8,"character":17},"member":"ShadowDom"},"template":"<div #starMain>\r\n</div>\r\n\r\n<!-- <ng-container *ngFor=\"let star of stars; let i = index;\">\r\n <span \r\n (click)=\"!isReadOnly && onRate(i)\" \r\n (mouseleave)=\"!isReadOnly && generateRating()\"\r\n (mouseenter)=\"!isReadOnly && onStar(i)\" \r\n [ngStyle]=\"{\r\n 'font-size': getSize(),\r\n 'width': getSize(),\r\n pointer: isReadOnly ? 'default' : 'pointer'\r\n }\" \r\n [ngClass]=\"{\r\n on: star.checked,\r\n half: star.isHalf,\r\n readOnly: isReadOnly,\r\n editable: !isReadOnly\r\n }\"></span>\r\n</ng-container> -->","styles":[":root{--checkedColor:gold;--unCheckedColor:gray;--size:24px;--halfWidth:10px;--halfMargin:-20px}.star{cursor:pointer;color:var(--unCheckedColor);font-size:var(--size);width:var(--size);display:inline-block}.star:last-child{margin-right:0}.star:before{content:'\\2605'}.star.on{color:var(--checkedColor)}.star.half:after{content:'\\2605';color:var(--checkedColor);position:absolute;margin-left:var(--halfMargin);width:var(--halfWidth);overflow:hidden}"]}]}],"members":{"mainElement":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":43,"character":3},"arguments":["starMain",{"static":true}]}]}],"__ctor__":[{"__symbolic":"constructor"}],"rate":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":118,"character":3}}]}],"checkedcolor":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":120,"character":3},"arguments":[{"__symbolic":"select","expression":{"__symbolic":"reference","name":"StarRatingComponent"},"member":"INP_CHECKED_COLOR"}]}]}],"uncheckedcolor":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":125,"character":3},"arguments":[{"__symbolic":"select","expression":{"__symbolic":"reference","name":"StarRatingComponent"},"member":"INP_UNCHECKED_COLOR"}]}]}],"value":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":130,"character":3},"arguments":[{"__symbolic":"select","expression":{"__symbolic":"reference","name":"StarRatingComponent"},"member":"INP_VALUE"}]}]}],"size":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":136,"character":3},"arguments":[{"__symbolic":"select","expression":{"__symbolic":"reference","name":"StarRatingComponent"},"member":"INP_SIZE"}]}]}],"readonly":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":142,"character":3},"arguments":[{"__symbolic":"select","expression":{"__symbolic":"reference","name":"StarRatingComponent"},"member":"INP_READONLY"}]}]}],"totalstars":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":147,"character":3},"arguments":[{"__symbolic":"select","expression":{"__symbolic":"reference","name":"StarRatingComponent"},"member":"INP_TOTALSTARS"}]}]}],"makeEditable":[{"__symbolic":"method"}],"makeReadOnly":[{"__symbolic":"method"}],"addRemoveEvents":[{"__symbolic":"method"}],"ngAfterViewInit":[{"__symbolic":"method"}],"onRate":[{"__symbolic":"method"}],"onStar":[{"__symbolic":"method"}],"offStar":[{"__symbolic":"method"}],"addDefaultClass":[{"__symbolic":"method"}],"addCheckedStarClass":[{"__symbolic":"method"}],"addHalfStarClass":[{"__symbolic":"method"}],"setStars":[{"__symbolic":"method"}],"applySizeAllStars":[{"__symbolic":"method"}],"applyColorStyleAllStars":[{"__symbolic":"method"}],"applyColorStyle":[{"__symbolic":"method"}],"applyCheckedColorStyle":[{"__symbolic":"method"}],"applyUnCheckedColorStyle":[{"__symbolic":"method"}],"generateRating":[{"__symbolic":"method"}]},"statics":{"VAR_CHECKED_COLOR":"--checkedColor","VAR_UNCHECKED_COLOR":"--unCheckedColor","VAR_SIZE":"--size","VAR_HALF_WIDTH":"--halfWidth","VAR_HALF_MARGIN":"--halfMargin","CLS_CHECKED_STAR":"on","CLS_DEFAULT_STAR":"star","CLS_HALF_STAR":"half","INP_CHECKED_COLOR":"checkedcolor","INP_UNCHECKED_COLOR":"uncheckedcolor","INP_VALUE":"value","INP_SIZE":"size","INP_READONLY":"readonly","INP_TOTALSTARS":"totalstars"}},"ɵa":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":2,"character":1},"arguments":[{"selector":"lib-rating","template":"\n <p>\n rating works!\n </p>\n ","styles":[]}]}],"members":{"__ctor__":[{"__symbolic":"constructor"}],"ngOnInit":[{"__symbolic":"method"}]}}},"origins":{"RatingModule":"./lib/rating.module","StarRatingComponent":"./components/star-rating/star-rating.component","ɵa":"./lib/rating.component"},"importAs":"ng-starrating"}
{"__symbolic":"module","version":4,"metadata":{"RatingModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":6,"character":1},"arguments":[{"imports":[{"__symbolic":"reference","module":"@angular/forms","name":"FormsModule","line":8,"character":4},{"__symbolic":"reference","module":"@angular/common","name":"CommonModule","line":9,"character":4}],"declarations":[{"__symbolic":"reference","name":"ɵa"},{"__symbolic":"reference","name":"StarRatingComponent"}],"exports":[{"__symbolic":"reference","name":"StarRatingComponent"}],"entryComponents":[{"__symbolic":"reference","name":"StarRatingComponent"}]}]}],"members":{"ngDoBootstrap":[{"__symbolic":"method"}]}},"StarRatingComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":4,"character":1},"arguments":[{"selector":"star-rating","encapsulation":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewEncapsulation","line":8,"character":17},"member":"ShadowDom"},"template":"<div #starMain>\r\n</div>\r\n\r\n<!-- <ng-container *ngFor=\"let star of stars; let i = index;\">\r\n <span \r\n (click)=\"!isReadOnly && onRate(i)\" \r\n (mouseleave)=\"!isReadOnly && generateRating()\"\r\n (mouseenter)=\"!isReadOnly && onStar(i)\" \r\n [ngStyle]=\"{\r\n 'font-size': getSize(),\r\n 'width': getSize(),\r\n pointer: isReadOnly ? 'default' : 'pointer'\r\n }\" \r\n [ngClass]=\"{\r\n on: star.checked,\r\n half: star.isHalf,\r\n readOnly: isReadOnly,\r\n editable: !isReadOnly\r\n }\"></span>\r\n</ng-container> -->","styles":[":root{--checkedColor:gold;--unCheckedColor:gray;--size:24px;--halfWidth:10px;--halfMargin:-20px}.star{cursor:pointer;color:var(--unCheckedColor);font-size:var(--size);width:var(--size);display:inline-block}.star:last-child{margin-right:0}.star:before{content:'\\2605'}.star.on{color:var(--checkedColor)}.star.half:after{content:'\\2605';color:var(--checkedColor);position:absolute;margin-left:var(--halfMargin);width:var(--halfWidth);overflow:hidden}"]}]}],"members":{"mainElement":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"ViewChild","line":43,"character":3},"arguments":["starMain",{"static":true}]}]}],"__ctor__":[{"__symbolic":"constructor"}],"rate":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":120,"character":3}}]}],"checkedcolor":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":122,"character":3},"arguments":[{"__symbolic":"select","expression":{"__symbolic":"reference","name":"StarRatingComponent"},"member":"INP_CHECKED_COLOR"}]}]}],"uncheckedcolor":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":127,"character":3},"arguments":[{"__symbolic":"select","expression":{"__symbolic":"reference","name":"StarRatingComponent"},"member":"INP_UNCHECKED_COLOR"}]}]}],"value":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":132,"character":3},"arguments":[{"__symbolic":"select","expression":{"__symbolic":"reference","name":"StarRatingComponent"},"member":"INP_VALUE"}]}]}],"size":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":138,"character":3},"arguments":[{"__symbolic":"select","expression":{"__symbolic":"reference","name":"StarRatingComponent"},"member":"INP_SIZE"}]}]}],"readonly":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":144,"character":3},"arguments":[{"__symbolic":"select","expression":{"__symbolic":"reference","name":"StarRatingComponent"},"member":"INP_READONLY"}]}]}],"totalstars":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":149,"character":3},"arguments":[{"__symbolic":"select","expression":{"__symbolic":"reference","name":"StarRatingComponent"},"member":"INP_TOTALSTARS"}]}]}],"makeEditable":[{"__symbolic":"method"}],"makeReadOnly":[{"__symbolic":"method"}],"addEvents":[{"__symbolic":"method"}],"ngAfterViewInit":[{"__symbolic":"method"}],"onRate":[{"__symbolic":"method"}],"onStar":[{"__symbolic":"method"}],"offStar":[{"__symbolic":"method"}],"addDefaultClass":[{"__symbolic":"method"}],"addCheckedStarClass":[{"__symbolic":"method"}],"addHalfStarClass":[{"__symbolic":"method"}],"setStars":[{"__symbolic":"method"}],"applySizeAllStars":[{"__symbolic":"method"}],"applyColorStyleAllStars":[{"__symbolic":"method"}],"applyColorStyle":[{"__symbolic":"method"}],"applyCheckedColorStyle":[{"__symbolic":"method"}],"applyUnCheckedColorStyle":[{"__symbolic":"method"}],"generateRating":[{"__symbolic":"method"}]},"statics":{"VAR_CHECKED_COLOR":"--checkedColor","VAR_UNCHECKED_COLOR":"--unCheckedColor","VAR_SIZE":"--size","VAR_HALF_WIDTH":"--halfWidth","VAR_HALF_MARGIN":"--halfMargin","CLS_CHECKED_STAR":"on","CLS_DEFAULT_STAR":"star","CLS_HALF_STAR":"half","INP_CHECKED_COLOR":"checkedcolor","INP_UNCHECKED_COLOR":"uncheckedcolor","INP_VALUE":"value","INP_SIZE":"size","INP_READONLY":"readonly","INP_TOTALSTARS":"totalstars"}},"ɵa":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":2,"character":1},"arguments":[{"selector":"lib-rating","template":"\n <p>\n rating works!\n </p>\n ","styles":[]}]}],"members":{"__ctor__":[{"__symbolic":"constructor"}],"ngOnInit":[{"__symbolic":"method"}]}}},"origins":{"RatingModule":"./lib/rating.module","StarRatingComponent":"./components/star-rating/star-rating.component","ɵa":"./lib/rating.component"},"importAs":"ng-starrating"}
{
"name": "ng-starrating",
"version": "1.0.13",
"version": "1.0.14",
"description": "Star Rating Library using Angular",

@@ -5,0 +5,0 @@ "peerDependencies": {

# ng-starrating
[![npm version](https://img.shields.io/badge/npm-v1.0.13-brightgreen.svg)](https://www.npmjs.com/package/ng-starrating/v/1.0.13)
[![npm version](https://img.shields.io/badge/npm-v1.0.14-brightgreen.svg)](https://www.npmjs.com/package/ng-starrating/v/1.0.14)
[![License](https://img.shields.io/badge/license-MIT-blue.svg)](https://github.com/riteshgandhi/ng-star-rating)

@@ -154,2 +154,3 @@

`v1.0.14 - [2020-02-11]`
`v1.0.13 - [2020-02-11]`

@@ -156,0 +157,0 @@ - minor fixes

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc