UNPKG

@agnos-ui/angular

Version:

Bootstrap-based widget library for Angular.

208 lines 25.9 kB
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) { returnRatingComponent_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"]}