@agnos-ui/angular
Version:
Bootstrap-based widget library for Angular.
208 lines • 25.9 kB
JavaScript
import { BaseWidgetDirective, SlotDirective, auBooleanAttribute, auNumberAttribute, callWidgetFactory, createRating } from '@agnos-ui/angular-headless';
import { ChangeDetectionStrategy, Component, ContentChild, Directive, EventEmitter, HostBinding, Input, Output, TemplateRef, ViewEncapsulation, forwardRef, inject, } from '@angular/core';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
import * as i0 from "@angular/core";
const _c0 = ["auRating", ""];
function _forTrack0($index, $item) { return this.trackByIndex($index); }
function RatingComponent_For_1_ng_template_3_Template(rf, ctx) { }
function RatingComponent_For_1_Template(rf, ctx) { if (rf & 1) {
const _r8 = i0.ɵɵgetCurrentView();
i0.ɵɵelementStart(0, "span", 0);
i0.ɵɵtext(1);
i0.ɵɵelementEnd();
i0.ɵɵelementStart(2, "span", 1);
i0.ɵɵlistener("mouseenter", function RatingComponent_For_1_Template_span_mouseenter_2_listener() { const restoredCtx = i0.ɵɵrestoreView(_r8); const index_r2 = restoredCtx.$index; const ctx_r7 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r7._widget.actions.hover(index_r2 + 1)); })("click", function RatingComponent_For_1_Template_span_click_2_listener() { const restoredCtx = i0.ɵɵrestoreView(_r8); const index_r2 = restoredCtx.$index; const ctx_r9 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r9._widget.actions.click(index_r2 + 1)); });
i0.ɵɵtemplate(3, RatingComponent_For_1_ng_template_3_Template, 0, 0, "ng-template", 2);
i0.ɵɵelementEnd();
} if (rf & 2) {
const index_r2 = ctx.$index;
const ctx_r0 = i0.ɵɵnextContext();
i0.ɵɵadvance();
i0.ɵɵtextInterpolate1("(", index_r2 < ctx_r0.state().visibleRating ? "*" : " ", ")");
i0.ɵɵadvance();
i0.ɵɵstyleProp("cursor", ctx_r0.state().isInteractive ? "pointer" : "default");
i0.ɵɵadvance();
i0.ɵɵproperty("auSlot", ctx_r0.state().slotStar)("auSlotProps", ctx_r0.state().stars[index_r2]);
} }
export class RatingStarDirective {
constructor() {
this.templateRef = inject((TemplateRef));
}
static ngTemplateContextGuard(_dir, context) {
return true;
}
static { this.ɵfac = function RatingStarDirective_Factory(t) { return new (t || RatingStarDirective)(); }; }
static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: RatingStarDirective, selectors: [["ng-template", "auRatingStar", ""]], standalone: true }); }
}
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(RatingStarDirective, [{
type: Directive,
args: [{ selector: 'ng-template[auRatingStar]', standalone: true }]
}], null, null); })();
export class RatingComponent extends BaseWidgetDirective {
constructor() {
super(...arguments);
this._widget = callWidgetFactory({
factory: createRating,
widgetName: 'rating',
events: {
onHover: (event) => this.hover.emit(event),
onLeave: (event) => this.leave.emit(event),
onRatingChange: (rating) => {
this.ratingChange.emit(rating);
this.onChange(rating);
},
},
});
this.onChange = (_) => { };
this.onTouched = () => { };
/**
* An event emitted when the user is hovering over a given rating.
*
* Event payload is equal to the rating being hovered over.
*/
this.hover = new EventEmitter();
/**
* An event emitted when the user stops hovering over a given rating.
*
* Event payload is equal to the rating of the last item being hovered over.
*/
this.leave = new EventEmitter();
/**
* An event emitted when the rating is changed.
*
* Event payload is equal to the newly selected rating.
*/
this.ratingChange = new EventEmitter();
}
// TODO angular is failing when adding this host binding in decorator part
get hostAriaLabelledBy() {
return this.state().ariaLabelledBy || null;
}
writeValue(value) {
this._widget.patch({ rating: value });
}
registerOnChange(fn) {
this.onChange = fn;
}
registerOnTouched(fn) {
this.onTouched = fn;
}
setDisabledState(disabled) {
this._widget.patch({ disabled });
}
ngAfterContentChecked() {
this._widget.patchSlots({
slotStar: this.slotStarFromContent?.templateRef,
});
}
trackByIndex(index) {
return index;
}
static { this.ɵfac = /*@__PURE__*/ (() => { let ɵRatingComponent_BaseFactory; return function RatingComponent_Factory(t) { return (ɵRatingComponent_BaseFactory || (ɵRatingComponent_BaseFactory = i0.ɵɵgetInheritedFactory(RatingComponent)))(t || RatingComponent); }; })(); }
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: RatingComponent, selectors: [["", "auRating", ""]], contentQueries: function RatingComponent_ContentQueries(rf, ctx, dirIndex) { if (rf & 1) {
i0.ɵɵcontentQuery(dirIndex, RatingStarDirective, 5);
} if (rf & 2) {
let _t;
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.slotStarFromContent = _t.first);
} }, hostAttrs: ["role", "slider", "aria-valuemin", "0", 1, "d-inline-flex", "au-rating"], hostVars: 10, hostBindings: function RatingComponent_HostBindings(rf, ctx) { if (rf & 1) {
i0.ɵɵlistener("blur", function RatingComponent_blur_HostBindingHandler() { return ctx.onTouched(); })("keydown", function RatingComponent_keydown_HostBindingHandler($event) { return ctx._widget.actions.handleKey($event); })("mouseleave", function RatingComponent_mouseleave_HostBindingHandler() { return ctx._widget.actions.leave(); });
} if (rf & 2) {
i0.ɵɵhostProperty("tabindex", ctx.state().tabindex);
i0.ɵɵattribute("aria-valuemax", ctx.state().maxRating)("aria-valuenow", ctx.state().visibleRating)("aria-valuetext", ctx.state().ariaValueText)("aria-disabled", ctx.state().disabled ? true : null)("aria-readonly", ctx.state().readonly ? true : null)("aria-label", ctx.state().ariaLabel || null)("aria-labelledby", ctx.hostAriaLabelledBy);
i0.ɵɵclassMap(ctx.state().className);
} }, inputs: { ariaValueTextFn: [i0.ɵɵInputFlags.None, "auAriaValueTextFn", "ariaValueTextFn"], disabled: [i0.ɵɵInputFlags.HasDecoratorInputTransform, "auDisabled", "disabled", auBooleanAttribute], maxRating: [i0.ɵɵInputFlags.HasDecoratorInputTransform, "auMaxRating", "maxRating", auNumberAttribute], rating: [i0.ɵɵInputFlags.HasDecoratorInputTransform, "auRating", "rating", auNumberAttribute], readonly: [i0.ɵɵInputFlags.HasDecoratorInputTransform, "auReadonly", "readonly", auBooleanAttribute], resettable: [i0.ɵɵInputFlags.HasDecoratorInputTransform, "auResettable", "resettable", auBooleanAttribute], slotStar: [i0.ɵɵInputFlags.None, "auSlotStar", "slotStar"], tabindex: [i0.ɵɵInputFlags.HasDecoratorInputTransform, "auTabindex", "tabindex", auNumberAttribute], className: [i0.ɵɵInputFlags.None, "auClassName", "className"], ariaLabel: [i0.ɵɵInputFlags.None, "auAriaLabel", "ariaLabel"], ariaLabelledBy: [i0.ɵɵInputFlags.None, "auAriaLabelledBy", "ariaLabelledBy"] }, outputs: { hover: "auHover", leave: "auLeave", ratingChange: "auRatingChange" }, standalone: true, features: [i0.ɵɵProvidersFeature([{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => RatingComponent), multi: true }]), i0.ɵɵInputTransformsFeature, i0.ɵɵInheritDefinitionFeature, i0.ɵɵStandaloneFeature], attrs: _c0, decls: 2, vars: 0, consts: [[1, "visually-hidden"], [1, "au-rating-star", 3, "mouseenter", "click"], [3, "auSlot", "auSlotProps"]], template: function RatingComponent_Template(rf, ctx) { if (rf & 1) {
i0.ɵɵrepeaterCreate(0, RatingComponent_For_1_Template, 4, 5, null, null, _forTrack0, true);
} if (rf & 2) {
i0.ɵɵrepeater(ctx.state().stars);
} }, dependencies: [SlotDirective], encapsulation: 2, changeDetection: 0 }); }
}
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(RatingComponent, [{
type: Component,
args: [{
selector: '[auRating]',
standalone: true,
imports: [SlotDirective],
changeDetection: ChangeDetectionStrategy.OnPush,
encapsulation: ViewEncapsulation.None,
host: {
class: 'd-inline-flex au-rating',
'[tabindex]': 'state().tabindex',
role: 'slider',
'aria-valuemin': '0',
'[attr.aria-valuemax]': 'state().maxRating',
'[attr.aria-valuenow]': 'state().visibleRating',
'[attr.aria-valuetext]': 'state().ariaValueText',
'[attr.aria-disabled]': 'state().disabled ? true : null',
'[attr.aria-readonly]': 'state().readonly ? true : null',
'[attr.aria-label]': 'state().ariaLabel || null',
'(blur)': 'onTouched()',
'(keydown)': '_widget.actions.handleKey($event)',
'(mouseleave)': '_widget.actions.leave()',
'[class]': 'state().className',
},
template: `
@for (item of state().stars; track trackByIndex(index); let index = $index) {
<span class="visually-hidden">({{ index < state().visibleRating ? '*' : ' ' }})</span>
<span
class="au-rating-star"
(mouseenter)="_widget.actions.hover(index + 1)"
(click)="_widget.actions.click(index + 1)"
[style.cursor]="state().isInteractive ? 'pointer' : 'default'"
>
<ng-template [auSlot]="state().slotStar" [auSlotProps]="state().stars[index]"></ng-template>
</span>
}
`,
providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => RatingComponent), multi: true }],
}]
}], null, { hostAriaLabelledBy: [{
type: HostBinding,
args: ['[attr.aria-labelledby]']
}], ariaValueTextFn: [{
type: Input,
args: ['auAriaValueTextFn']
}], disabled: [{
type: Input,
args: [{ alias: 'auDisabled', transform: auBooleanAttribute }]
}], maxRating: [{
type: Input,
args: [{ alias: 'auMaxRating', transform: auNumberAttribute }]
}], rating: [{
type: Input,
args: [{ alias: 'auRating', transform: auNumberAttribute }]
}], readonly: [{
type: Input,
args: [{ alias: 'auReadonly', transform: auBooleanAttribute }]
}], resettable: [{
type: Input,
args: [{ alias: 'auResettable', transform: auBooleanAttribute }]
}], slotStar: [{
type: Input,
args: ['auSlotStar']
}], slotStarFromContent: [{
type: ContentChild,
args: [RatingStarDirective, { static: false }]
}], tabindex: [{
type: Input,
args: [{ alias: 'auTabindex', transform: auNumberAttribute }]
}], className: [{
type: Input,
args: ['auClassName']
}], ariaLabel: [{
type: Input,
args: ['auAriaLabel']
}], ariaLabelledBy: [{
type: Input,
args: ['auAriaLabelledBy']
}], hover: [{
type: Output,
args: ['auHover']
}], leave: [{
type: Output,
args: ['auLeave']
}], ratingChange: [{
type: Output,
args: ['auRatingChange']
}] }); })();
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(RatingComponent, { className: "RatingComponent", filePath: "components/rating/rating.component.ts", lineNumber: 66 }); })();
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rating.component.js","sourceRoot":"","sources":["../../../../src/components/rating/rating.component.ts"],"names":[],"mappings":"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","sourcesContent":["import type {AdaptSlotContentProps, RatingWidget, SlotContent, StarContext} from '@agnos-ui/angular-headless';\nimport {BaseWidgetDirective, SlotDirective, auBooleanAttribute, auNumberAttribute, callWidgetFactory, createRating} from '@agnos-ui/angular-headless';\nimport type {AfterContentChecked} from '@angular/core';\nimport {\n\tChangeDetectionStrategy,\n\tComponent,\n\tContentChild,\n\tDirective,\n\tEventEmitter,\n\tHostBinding,\n\tInput,\n\tOutput,\n\tTemplateRef,\n\tViewEncapsulation,\n\tforwardRef,\n\tinject,\n} from '@angular/core';\nimport type {ControlValueAccessor} from '@angular/forms';\nimport {NG_VALUE_ACCESSOR} from '@angular/forms';\n\n@Directive({selector: 'ng-template[auRatingStar]', standalone: true})\nexport class RatingStarDirective {\n\tpublic templateRef = inject(TemplateRef<AdaptSlotContentProps<StarContext>>);\n\tstatic ngTemplateContextGuard(_dir: RatingStarDirective, context: unknown): context is StarContext {\n\t\treturn true;\n\t}\n}\n\n@Component({\n\tselector: '[auRating]',\n\tstandalone: true,\n\timports: [SlotDirective],\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n\tencapsulation: ViewEncapsulation.None,\n\thost: {\n\t\tclass: 'd-inline-flex au-rating',\n\t\t'[tabindex]': 'state().tabindex',\n\t\trole: 'slider',\n\t\t'aria-valuemin': '0',\n\t\t'[attr.aria-valuemax]': 'state().maxRating',\n\t\t'[attr.aria-valuenow]': 'state().visibleRating',\n\t\t'[attr.aria-valuetext]': 'state().ariaValueText',\n\t\t'[attr.aria-disabled]': 'state().disabled ? true : null',\n\t\t'[attr.aria-readonly]': 'state().readonly ? true : null',\n\t\t'[attr.aria-label]': 'state().ariaLabel || null',\n\t\t'(blur)': 'onTouched()',\n\t\t'(keydown)': '_widget.actions.handleKey($event)',\n\t\t'(mouseleave)': '_widget.actions.leave()',\n\t\t'[class]': 'state().className',\n\t},\n\ttemplate: `\n\t\t@for (item of state().stars; track trackByIndex(index); let index = $index) {\n\t\t\t<span class=\"visually-hidden\">({{ index < state().visibleRating ? '*' : ' ' }})</span>\n\t\t\t<span\n\t\t\t\tclass=\"au-rating-star\"\n\t\t\t\t(mouseenter)=\"_widget.actions.hover(index + 1)\"\n\t\t\t\t(click)=\"_widget.actions.click(index + 1)\"\n\t\t\t\t[style.cursor]=\"state().isInteractive ? 'pointer' : 'default'\"\n\t\t\t>\n\t\t\t\t<ng-template [auSlot]=\"state().slotStar\" [auSlotProps]=\"state().stars[index]\"></ng-template>\n\t\t\t</span>\n\t\t}\n\t`,\n\tproviders: [{provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => RatingComponent), multi: true}],\n})\nexport class RatingComponent extends BaseWidgetDirective<RatingWidget> implements ControlValueAccessor, AfterContentChecked {\n\treadonly _widget = callWidgetFactory({\n\t\tfactory: createRating,\n\t\twidgetName: 'rating',\n\t\tevents: {\n\t\t\tonHover: (event) => this.hover.emit(event),\n\t\t\tonLeave: (event) => this.leave.emit(event),\n\t\t\tonRatingChange: (rating: number) => {\n\t\t\t\tthis.ratingChange.emit(rating);\n\t\t\t\tthis.onChange(rating);\n\t\t\t},\n\t\t},\n\t});\n\n\tonChange = (_: any) => {};\n\tonTouched = () => {};\n\n\t// TODO angular is failing when adding this host binding in decorator part\n\t@HostBinding('[attr.aria-labelledby]') get hostAriaLabelledBy() {\n\t\treturn this.state().ariaLabelledBy || null;\n\t}\n\n\t/**\n\t * Return the value for the 'aria-valuetext' attribute.\n\t */\n\t@Input('auAriaValueTextFn') ariaValueTextFn: ((rating: number, maxRating: number) => string) | undefined;\n\n\t/**\n\t * If `true`, the rating is disabled.\n\t */\n\t@Input({alias: 'auDisabled', transform: auBooleanAttribute}) disabled: boolean | undefined;\n\n\t/**\n\t * The maximum rating that can be given.\n\t */\n\t@Input({alias: 'auMaxRating', transform: auNumberAttribute}) maxRating: number | undefined;\n\n\t/**\n\t * The current rating. Could be a decimal value like `3.75`.\n\t */\n\t@Input({alias: 'auRating', transform: auNumberAttribute}) rating: number | undefined;\n\n\t/**\n\t * If `true`, the rating can't be changed.\n\t */\n\t@Input({alias: 'auReadonly', transform: auBooleanAttribute}) readonly: boolean | undefined;\n\n\t/**\n\t * Define if the rating can be reset.\n\t *\n\t * If set to true, the user can 'unset' the rating value by cliking on the current rating value.\n\t */\n\t@Input({alias: 'auResettable', transform: auBooleanAttribute}) resettable: boolean | undefined;\n\n\t@Input('auSlotStar') slotStar: SlotContent<AdaptSlotContentProps<StarContext>>;\n\t@ContentChild(RatingStarDirective, {static: false}) slotStarFromContent: RatingStarDirective | undefined;\n\n\t/**\n\t * Allows setting a custom rating tabindex.\n\t * If the component is disabled, `tabindex` will still be set to `-1`.\n\t */\n\t@Input({alias: 'auTabindex', transform: auNumberAttribute}) tabindex: number | undefined;\n\n\t/**\n\t * CSS classes to be applied on the widget main container\n\t */\n\t@Input('auClassName') className: string | undefined;\n\n\t/**\n\t * The aria label\n\t */\n\t@Input('auAriaLabel') ariaLabel: string | undefined;\n\n\t/**\n\t * The aria labelled by\n\t */\n\t@Input('auAriaLabelledBy') ariaLabelledBy: string | undefined;\n\n\t/**\n\t * An event emitted when the user is hovering over a given rating.\n\t *\n\t * Event payload is equal to the rating being hovered over.\n\t */\n\t@Output('auHover') hover = new EventEmitter<number>();\n\n\t/**\n\t * An event emitted when the user stops hovering over a given rating.\n\t *\n\t * Event payload is equal to the rating of the last item being hovered over.\n\t */\n\t@Output('auLeave') leave = new EventEmitter<number>();\n\n\t/**\n\t * An event emitted when the rating is changed.\n\t *\n\t * Event payload is equal to the newly selected rating.\n\t */\n\t@Output('auRatingChange') ratingChange = new EventEmitter<number>();\n\n\twriteValue(value: any): void {\n\t\tthis._widget.patch({rating: value});\n\t}\n\n\tregisterOnChange(fn: (value: any) => any): void {\n\t\tthis.onChange = fn;\n\t}\n\n\tregisterOnTouched(fn: () => any): void {\n\t\tthis.onTouched = fn;\n\t}\n\n\tsetDisabledState(disabled: boolean): void {\n\t\tthis._widget.patch({disabled});\n\t}\n\n\tngAfterContentChecked(): void {\n\t\tthis._widget.patchSlots({\n\t\t\tslotStar: this.slotStarFromContent?.templateRef,\n\t\t});\n\t}\n\n\ttrackByIndex(index: number) {\n\t\treturn index;\n\t}\n}\n"]}