Как стилизовать селектор списка выбора RadDataForm - PullRequest
0 голосов
/ 06 июня 2019

У меня есть RadDataForm в приложении Nativescript-Angular.

Этот RadDataForm показывает средство выбора списков для одного из моих свойств.

Я читал о стилизации компонентов RadDataForm, но отсутствует часть о том, как стилизовать «тексты колесика», которые отображаются, когда я меняю дату. (Или я что-то упустил?)

Они остаются черными, но я нуждаюсь в них в другом цвете (то есть белом)

Я уже решил это для DatePicker, но это не работает для Listpicker "правильно" -> Он меняет цвет после того, как я изменяю выбор.

У меня есть детская площадка , настроенная и тестируемая на устройстве iOS.

1 Ответ

0 голосов
/ 19 июня 2019

Обыскав много, я нашел приложение Nativescript-Example .

Внутри этого приложения есть также RadDataForm со стилем выбора списка. Приложение также показывает используемый код для примера.

Внутри моего компонента у меня есть:

onEditorSetup(event: DataFormEventData) {

    const property = this.myDataForm.dataForm.getPropertyByName(event.propertyName);
    const t = property.editor.type;
    if (t === DataFormEditorType.Picker) {
        console.log("found picker editor for " + property.displayName);
        if (app.ios) {
            this.setupPickerViewEditor(event);
        }
    }
}

setupPickerViewEditor(event: DataFormEventData) {
        console.log("setting up editor: " + event.editor);
        const delegate = UIPickerViewDelegateImplementation.new().initWithOwner(event.editor);
        this.delegates.set(event.propertyName, delegate); // storing the delegate cause they are weak references.
        event.editor.pickerView.delegate = delegate;
    }

Моя реализация для делегата средства выбора, который имеет белый текст:

export class UIPickerViewDelegateImplementation extends NSObject implements UIPickerViewDelegate {

    static ObjCProtocols = [UIPickerViewDelegate];
    static new(): UIPickerViewDelegateImplementation {
        return <UIPickerViewDelegateImplementation> super.new();
    }

    private _owner: any; // TKDataFormPickerViewEditor

    initWithOwner(owner: any /* TKDataFormPickerViewEditor */): UIPickerViewDelegateImplementation {
        this._owner = owner;

        return this;
    }

    pickerViewTitleForRowForComponent(pickerView: UIPickerView, row: number, component: number): string {
        return this._owner.options[row];
    }

    pickerViewDidSelectRowInComponent(pickerView: UIPickerView, row: number, component: number): void {
        this._owner.selectedIndex = row;
        this._owner.owner.editorValueChanged(this._owner);
    }

    pickerViewAttributedTitleForRowForComponent(pickerView: UIPickerView, row: number, component: number): NSAttributedString {
        const title = this.pickerViewTitleForRowForComponent(pickerView, row, component);
        const attr = NSDictionary.dictionaryWithObjectForKey(UIColor.whiteColor, NSForegroundColorAttributeName);
        const res = NSAttributedString.alloc().initWithStringAttributes(title, attr);

        return res;
    }
}
...