nativescriptnativescript-angularradlistview

Nativescript angular radListView `itemSelecting` example


Is there anyone knows a link which shows an example on how to implement itemSelecting in Nativescript angular RadListViewhttps://docs.nativescript.org/ns-ui-api-reference/classes/radlistview#itemselecting?

Because I can't find any example. Thank you.


Solution

  • HTML

    <RadListView class="list-group" [items]="countries" selectionBehavior="Press"
        multipleSelection="true" (itemSelecting)="onItemSelecting($event)"
        (itemDeselecting)="onItemSelecting($event)">
        <ng-template let-country="item">
            <FlexboxLayout flexDirection="row" class="list-group-item">
                <Image [src]="country.imageSrc" class="thumb img-circle"></Image>
                <Label [text]="country.name" class="list-group-item-heading"
                    verticalAlignment="center" style="width: 60%"></Label>
            </FlexboxLayout>
        </ng-template>
    </RadListView>
    

    TS

    import { ListViewEventData } from "nativescript-ui-listview"
    import { Component } from "@angular/core";
    
    @Component({
        selector: "Home",
        moduleId: module.id,
        templateUrl: "./home.component.html",
        styleUrls: ["./home.component.css"]
    })
    export class HomeComponent {
        countries: { name: string, imageSrc: string }[] = [
            { name: "Australia", imageSrc: "https://play.nativescript.org/dist/assets/img/flags/au.png" },
            { name: "Belgium", imageSrc: "https://play.nativescript.org/dist/assets/img/flags/be.png" },
            { name: "Bulgaria", imageSrc: "https://play.nativescript.org/dist/assets/img/flags/bg.png" },
            { name: "Canada", imageSrc: "https://play.nativescript.org/dist/assets/img/flags/ca.png" },
            { name: "Switzerland", imageSrc: "https://play.nativescript.org/dist/assets/img/flags/ch.png" },
            { name: "China", imageSrc: "https://play.nativescript.org/dist/assets/img/flags/cn.png" },
            { name: "Czech Republic", imageSrc: "https://play.nativescript.org/dist/assets/img/flags/cz.png" },
            { name: "Germany", imageSrc: "https://play.nativescript.org/dist/assets/img/flags/de.png" },
            { name: "Spain", imageSrc: "https://play.nativescript.org/dist/assets/img/flags/es.png" },
            { name: "Ethiopia", imageSrc: "https://play.nativescript.org/dist/assets/img/flags/et.png" },
            { name: "Croatia", imageSrc: "https://play.nativescript.org/dist/assets/img/flags/hr.png" },
            { name: "Hungary", imageSrc: "https://play.nativescript.org/dist/assets/img/flags/hu.png" },
            { name: "Italy", imageSrc: "https://play.nativescript.org/dist/assets/img/flags/it.png" },
            { name: "Jamaica", imageSrc: "https://play.nativescript.org/dist/assets/img/flags/jm.png" },
            { name: "Romania", imageSrc: "https://play.nativescript.org/dist/assets/img/flags/ro.png" },
            { name: "Russia", imageSrc: "https://play.nativescript.org/dist/assets/img/flags/ru.png" },
            { name: "United States", imageSrc: "https://play.nativescript.org/dist/assets/img/flags/us.png" },
        ];
    
        onItemSelecting(args: ListViewEventData): void {
            console.log(args.view.bindingContext.name);
            args.returnValue = args.index > 5;
        }
    }
    

    Note: It seems to be buggy, at least on Android. Second tap fails to fire itemSelecting event and marks the item as selected. A workaround could be found at nativescript-ui-feedback/issues/181