Appfigurate™️
HomeDocumentation
  • Introducing Appfigurate™️ 3
  • Getting Started
    • Getting Started
    • Examples
    • Upgrade guide
      • v1.4.0 to v2.2.0
      • v2.1.1 to v2.2.0
      • v2.2.1 to v3.0.0
      • v3.2.1 to v4.0.0
    • iOS native app integration
      • iOS app extension integration
    • watchOS app integration
      • watchOS app extension integration
    • Android native app integration
    • Mobile Flutter integration
      • Flutter iOS
      • Flutter Android
    • React Native integration
      • iOS native module integration
      • Android native module integration
      • JavaScript integration
    • Third party remote configuration providers
      • Firebase Remote Config
      • Launch Darkly
      • Other third party remote configuration providers
  • Configuration subclasses
    • Supported property types
      • Boolean
      • Integer
      • Float
      • Double
      • Plain String
      • Encrypted String
    • Custom executable actions
    • Slider icon types
  • Additional reading
    • Info.plist options
    • AndroidManifest.xml options
    • Displaying overridden configuration
    • Security
      • Best practice
      • Encryption
      • Export compliance
      • App Store compliance
      • PrivacyInfo.xcprivacy
      • Rotating your private key
  • Automation testing
    • iOS native app automation testing
    • Android native automation testing
  • API
    • iOS and watchOS API
    • Android API
    • Mobile Flutter API
    • React Native API
  • Appfigurate User Guide
    • Introduction
    • Main menu
    • Select app
    • Add app
    • Import app
    • Install example apps
    • Settings
      • Passcode Lock
      • Restore
      • Backup
      • Delete all apps and Settings
      • Analytics
    • Edit app
    • Configure app
    • Permissions
  • Appfigurate SE user guide
    • Introduction
    • Manual encryption
      • ENCRYPTED_STRING macro/function
      • ENCRYPTED_STRING_IOS_WATCHOS macro/function
    • Setup iOS Simulator app
    • Setup Android Emulator app
    • Xcode source editor extension
      • Troubleshooting
    • Real device cloud testing services
      • BrowserStack
  • LEGAL
    • License Agreement
    • Privacy Policy
    • Release History
    • Third party notices
Powered by GitBook
On this page
  • Local properties
  • Slider UI
  • Editable UI
  • List UI
  • Editable List UI
  • Remote properties
  • Remote Editable UI
  1. Configuration subclasses
  2. Supported property types

Double

PreviousFloatNextPlain String

Last updated 4 months ago

Double is a double-precision 8 byte floating-point type with an approximate range of 2.3E-308 to 1.7E+308.

The default value of a Double is 0.0. You can change the default value of the property by assigning a new value in an overridden method.

double is a double-precision 8 byte floating-point type with an approximate range of 2.3E-308 to 1.7E+308.

The default value of a double is 0.0. You can change the default value of the property by assigning a new value in an overridden method.

double properties should be declared in your subclass header file as follows:

@import AppfigurateLibrary;

@interface Configuration : APLConfiguration

@property(nonatomic, assign) double propertyName;
...

Double is a double-precision 8 byte floating-point type with an approximate range of 2.3E-308 to 1.7E+308.

The default value of a Double is 0.0. You can change the default value of the property by assigning a new value in an overridden method.

double is a double-precision 8 byte floating-point type with an approximate range of 2.3E-308 to 1.7E+308.

The default value of a double is 0.0. You can change the default value of the property by assigning a new value in an overridden method.

The flutter class defers to the underlying platform (iOS) or (Android) subclass to read property values.

The React Native module AppfigurateModule class defers to the underlying platform (iOS) or (Android) subclass to read property values.

React Native always converts the underlying Double to a JavaScript Number - you should be aware of .

Local properties

Slider UI

Allows a double property to be changed in Appfigurate using a slider between minimum and maximum values.

Swift prototype

@DoublePropertySlider(min, max, icon, description, restart)
var propertyName: Double

You can customize the minimum and maximum images using the parameter. If restart is true, then the app will be restarted if the property value changes.

Swift example

import AppfigurateLibrary

@objcMembers class Configuration: APLConfiguration {

    @DoublePropertySlider(min: 60.5, max: 120.41, icon: .volume, description: "Clipping - decibels", restart: false)
    var maxDecibel: Double
    
    override func reset() {
        maxDecibel = 100.0
    }
    ...

Objective-C prototype

DOUBLE_PROPERTY_SLIDER(propertyName, minValue, maxValue, icon, description, restart)

You can customize the minimum and maximum images using the parameter. If restart is YES, then the app will be restarted if the property value changes.

Objective-C example

@import AppfigurateLibrary;

@interface Configuration : APLConfiguration

@property(nonatomic, assign) double maxDecibel;

@end

@implementation Configuration

DOUBLE_PROPERTY_SLIDER(maxDecibel, 60.5, 120.41, APLIconSliderVolume, @"Clipping - decibels", NO);

- (void) reset {
    self.maxDecibel = 100.0;
}
...

Kotlin prototype

@DoublePropertySlider(description, minValue, maxValue, sliderIcon, restart)
var propertyName = 0.0

Kotlin example

import nz.co.electricbolt.appfiguratelibrary.Configuration
import nz.co.electricbolt.appfiguratelibrary.annotations.DoublePropertySlider
import nz.co.electricbolt.appfiguratelibrary.annotations.IconSlider

class AppConfiguration : Configuration() {

    @DoublePropertySlider(minValue = 60.5, max = 120.41, sliderIcon = IconSlider.IconSliderVolume, description = "Clipping - decibels", restart = false)
    var maxDecibel = 0.0
    
    override fun reset() {
        super.reset()
        maxDecibel = 100.0
    }
    ...

Java prototype

@DoublePropertySlider(description, minValue, maxValue, sliderIcon, restart)
double propertyName;

Java example

import nz.co.electricbolt.appfiguratelibrary.Configuration;
import nz.co.electricbolt.appfiguratelibrary.annotations.DoublePropertySlider;
import nz.co.electricbolt.appfiguratelibrary.annotations.IconSlider;

public class AppConfiguration extends Configuration {

    @DoublePropertySlider(minValue = 60.5, max = 120.41, sliderIcon = IconSlider.IconSliderVolume, description = "Clipping - decibels", restart = false)
    public double maxDecibel;
    
    @Override
    public void reset() {
        super.reset();
        this.maxDecibel = 100.0;
    }
    ...

Dart prototype

double get propertyName => nativeDouble('propertyName');

Dart example

import 'package:appfigurateflutter/appfigurateflutter.dart';

public class Configuration extends APLNativeConfiguration {

    double get maxDecibel => nativeDouble('maxDecibel');
    ...

JavaScript example

import {
  NativeModules,
} from 'react-native';

const {Appfigurate} = NativeModules;

...

let maxDecibel = await Appfigurate.nativeValue("maxDecibel"); // Number

Editable UI

Allows a double property to be changed in Appfigurate using a text field between minimum and maximum values, and an optional regular expression validating input.

Swift prototype

@DoublePropertyEdit(min, max, regex, description, restart)
var propertyName: Double

If restart is true, then the app will be restarted if the property value changes.

Swift example

import AppfigurateLibrary

@objcMembers class Configuration: APLConfiguration {

    @DoublePropertyEdit(min: -2.1, max: 4.1, regex: "", description: "Shot accuracy", restart: false)
    var shotAccuracy: Double
    
    override func reset() {
        shotAccuracy = 3.241
    }
    ...

Objective-C prototype

DOUBLE_PROPERTY_EDIT(propertyName, minValue, maxValue, regex, description, restart)

If restart is YES, then the app will be restarted if the property value changes.

Objective-C example

@import AppfigurateLibrary;

@interface Configuration : APLConfiguration

@property(nonatomic, assign) double shotAccuracy;

@end

@implementation Configuration

DOUBLE_PROPERTY_EDIT(shotAccuracy, -2.1, 4.1, @"", @"Shot accuracy", NO);

- (void) reset {
    self.shotAccuracy = 3.241;
}
...

Kotlin prototype

@DoublePropertyEdit(description, minValue, maxValue, regularExpression, restart)
var propertyName = 0.0

If restart is true, then the app will be restarted if the property value changes.

Kotlin example

import nz.co.electricbolt.appfiguratelibrary.Configuration
import nz.co.electricbolt.appfiguratelibrary.annotations.DoublePropertyEdit

class AppConfiguration : Configuration() {

    @DoublePropertyEdit(description = "Shot accuracy", minValue = -2.1, maxValue = 4.1f, regularExpression = "", restart = false)
    var shotAccuracy = 0.0
    
    override fun reset() {
        super.reset()
        shotAccuracy = 3.241
    }
    ...

Java prototype

@DoublePropertyEdit(description, minValue, maxValue, regularExpression, restart)
double propertyName;

If restart is true, then the app will be restarted if the property value changes.

Java example

import nz.co.electricbolt.appfiguratelibrary.Configuration;
import nz.co.electricbolt.appfiguratelibrary.annotations.DoublePropertyEdit;

public class AppConfiguration extends Configuration {

    @DoublePropertyEdit(description = "Shot accuracy", minValue = -2.1, maxValue = 4.1, regularExpression = "", restart = false)
    public double shotAccuracy;
    
    @Override
    public void reset() {
        super.reset();
        this.shotAccuracy = 3.241;
    }
    ...

Dart prototype

double get propertyName => nativeDouble('propertyName');

Dart example

import 'package:appfigurateflutter/appfigurateflutter.dart';

public class Configuration extends APLNativeConfiguration {

    double get shotAccuracy => nativeDouble('shotAccuracy');
    ...

JavaScript example

import {
  NativeModules,
} from 'react-native';

const {Appfigurate} = NativeModules;

...

let shotAccuracy = await Appfigurate.nativeValue("shotAccuracy"); // Number

List UI

Allows a double property to be changed in Appfigurate by allowing the user to select from a predefined list of valid choices.

Swift prototype

@DoublePropertyList(description, restart, values)
var propertyName: Double

If restart is true, then the app will be restarted if the property value changes.

Swift example

import AppfigurateLibrary

@objcMembers class Configuration: APLConfiguration {

    @DoublePropertyList(description: "Quality rating", restart: true, values: ["Low": 10.0, "Average": 50.0, "Excellent": 95.0])
    var rating: Double
    
    override func reset() {
        qualityRating = 10.0
    }
    ...

Objective-C prototype

DOUBLE_PROPERTY_LIST(propertyName, description, restart, ...)

If restart is YES, then the app will be restarted if the property value changes.

Objective-C example

@import AppfigurateLibrary;

@interface Configuration : APLConfiguration

@property(nonatomic, assign) double rating;

@end

@implementation Configuration

DOUBLE_PROPERTY_LIST(rating, @"Quality rating", NO, @{@"Low": @10.0, @"Average": @50.0, @"Excellent": @95.0});

- (void) reset {
    self.rating = 10.0;
}
...

Kotlin prototype

@DoublePropertyList(description, keys, values, restart)
var propertyName = 0.0

If restart is true, then the app will be restarted if the property value changes.

Kotlin example

import nz.co.electricbolt.appfiguratelibrary.Configuration
import nz.co.electricbolt.appfiguratelibrary.annotations.DoublePropertyList

class AppConfiguration : Configuration() {

    @DoublePropertyList(description = "Quality rating", keys = ["Low", "Average", "Excellent"], values = [10.0, 50.0, 95.0], restart = false)
    var rating = 0.0
    
    override fun reset() {
        super.reset()
        rating = 10.0
    }
    ...

Java prototype

@DoublePropertyList(description, keys, values, restart)
double propertyName;

If restart is true, then the app will be restarted if the property value changes.

Java example

import nz.co.electricbolt.appfiguratelibrary.Configuration;
import nz.co.electricbolt.appfiguratelibrary.annotations.DoublePropertyList;

public class AppConfiguration extends Configuration {

    @DoublePropertyList(description = "Quality rating", keys = {"Low", "Average", "Excellent"}, values = {10.0, 50.0, 95.0}, restart = false)
    public double rating;
    
    @Override
    public void reset() {
        super.reset();
        this.rating = 10.0;
    }
    ...

Dart prototype

double get propertyName => nativeDouble('propertyName');

Dart example

import 'package:appfigurateflutter/appfigurateflutter.dart';

public class Configuration extends APLNativeConfiguration {

    double get rating => nativeDouble('rating');
    ...

JavaScript example

import {
  NativeModules,
} from 'react-native';

const {Appfigurate} = NativeModules;

...

let rating = await Appfigurate.nativeValue("rating"); // Number

Editable List UI

Allows a double property to be changed in Appfigurate by allowing the user to select from a predefined list of valid choices. The user can customize the list adding by additional values using a text field between minimum and maximum values, and an optional regular expression validating input.

Swift prototype

@DoublePropertyListEdit(min, max, regex, description, restart, values)
var propertyName: Double

If restart is true, then the app will be restarted if the property value changes.

Swift example

import AppfigurateLibrary

@objcMembers class Configuration: APLConfiguration {

    @DoublePropertyListEdit(min: 0.0, max: 366.0, regex: #"^(0?[0-9]?[0-9]|[1-2][0-9][0-9]|3[0-5][0-9]|36[0-5])?(?:\.\d+)?$"#, description: "Forward server time (days)", restart: false, values: ["7 days": 7.0, "1 month": 30.0, "1 Year": 365.0])
    var forwardServerTime: Double
    
    override func reset() {
        forwardServerTime = 7.0
    }
    ...

Objective-C prototype

DOUBLE_PROPERTY_LIST_EDIT(propertyName, minValue, maxValue, regex, description, restart, ...)

If restart is YES, then the app will be restarted if the property value changes.

Objective-C example

@import AppfigurateLibrary;

@interface Configuration : APLConfiguration

@property(nonatomic, assign) double forwardServerTime;

@end

@implementation Configuration

DOUBLE_PROPERTY_LIST_EDIT(forwardServerTime, 0.0, 366.0, @"^(0?[0-9]?[0-9]|[1-2][0-9][0-9]|3[0-5][0-9]|36[0-5])?(?:\\.\\d+)?$", @"Forward server time (days)", NO, @{@"7 days": @7.0, @"1 month": @30.0, @"1 Year": @365.0});

- (void) reset {
    self.forwardServerTime = 7.0;
}
...

Kotlin prototype

@DoublePropertyListEdit(description, regularExpression, minValue, maxValue, keys, values, restart)
var propertyName = 0.0

If restart is true, then the app will be restarted if the property value changes.

Kotlin example

import nz.co.electricbolt.appfiguratelibrary.Configuration
import nz.co.electricbolt.appfiguratelibrary.annotations.DoublePropertyListEdit

class AppConfiguration : Configuration() {

    @DoublePropertyListEdit(description = "Forward server time (days)", minValue = 0.0, maxValue = 366.0, regularExpression = "^(0?[0-9]?[0-9]|[1-2][0-9][0-9]|3[0-5][0-9]|36[0-5])$", keys = ["7 days", "1 month", "1 Year"], values = [7.0, 30.0, 365.0], restart = false)
    var forwardServerTime = 0.0
    
    override fun reset() {
        super.reset()
        forwardServerTime = 7.0
    }
    ...

Java prototype

@DoublePropertyListEdit(description, regularExpression, minValue, maxValue, keys, values, restart)
double propertyName;

If restart is true, then the app will be restarted if the property value changes.

Java example

import nz.co.electricbolt.appfiguratelibrary.Configuration;
import nz.co.electricbolt.appfiguratelibrary.annotations.DoublePropertyListEdit;

public class AppConfiguration extends Configuration {

    @DoublePropertyListEdit(description = "Forward server time (days)", minValue = 0.0, maxValue = 366.0, regularExpression = "^(0?[0-9]?[0-9]|[1-2][0-9][0-9]|3[0-5][0-9]|36[0-5])$", keys = {"7 days", "1 month", "1 Year"}, values = {7.0, 30.0, 365.0}, restart = false)
    public double forwardServerTime;
    
    @Override
    public void reset() {
        super.reset();
        this.forwardServerTime = 7.0;
    }
    ...

Dart prototype

double get propertyName => nativeDouble('propertyName');

Dart example

import 'package:appfigurateflutter/appfigurateflutter.dart';

public class Configuration extends APLNativeConfiguration {

    double get forwardServerTime => nativeDouble('forwardServerTime');
    ...

JavaScript example

import {
  NativeModules,
} from 'react-native';

const {Appfigurate} = NativeModules;

...

let forwardServerTime = await Appfigurate.nativeValue("forwardServerTime"); // Number

Remote properties

Remote Editable UI

Third party remote configuration provider integration is currently in private beta and will be available in the next major release of Appfigurate.

Allows a third party remote configuration provider's double property to be changed locally in Appfigurate using a text field. If the override tick box is ticked off, the third party remote configuration provider's value is displayed. If the override tick box is ticked on, then you can use Appfigurate to locally override the value.

Swift prototype

@RemoteDoublePropertyEdit(remoteKey, description, restart)
var propertyName: Double

Swift example

import AppfigurateLibrary

@objcMembers class Configuration: APLConfiguration {

    @RemoteDoublePropertyEdit(remoteKey: "fontSize", description: "Size of font throughout app")
    var fontSize: Double
    
    override func reset() {
        fontSize = 13.0
    }
    ...

Objective-C prototype

REMOTE_DOUBLE_PROPERTY_EDIT(propertyName, remoteKey, description)

Objective-C example

@import AppfigurateLibrary;

@interface Configuration : APLConfiguration

@property(nonatomic, assign) double fontSize;

@end

@implementation Configuration

REMOTE_DOUBLE_PROPERTY_EDIT(fontSize, @"Size of font throughout app");

- (void) reset {
    self.fontSize = 13.0;
}
...

Kotlin prototype

@RemoteDoublePropertyEdit(remoteKey, description)
var propertyName = 0.0

Kotlin example

import nz.co.electricbolt.appfiguratelibrary.Configuration
import nz.co.electricbolt.appfiguratelibrary.annotations.RemoteDoublePropertyEdit

class AppConfiguration : Configuration() {

    @RemoteDoublePropertyEdit(remoteKey = "fontSize", description = "Size of font throughout app")
    var fontSize = 0.0
    
    override fun reset() {
        super.reset()
        fontSize = 13.0
    }
    ...

Java prototype

@RemoteDoublePropertyEdit(remoteKey, description)
double propertyName;

Java example

import nz.co.electricbolt.appfiguratelibrary.Configuration;
import nz.co.electricbolt.appfiguratelibrary.annotations.RemoteDoublePropertyEdit;

public class AppConfiguration extends Configuration {

    @RemoteDoublePropertyEdit(remoteKey = "fontSize", description = "Size of font throughout app")
    public double fontSize;
    
    @Override
    public void reset() {
        super.reset();
        this.fontSize = 13.0;
    }
    ...

Dart prototype

double get propertyName => nativeDouble('propertyName');

Dart example

import 'package:appfigurateflutter/appfigurateflutter.dart';

public class Configuration extends APLNativeConfiguration {

    double get fontSize => nativeDouble('fontSize');
    ...

JavaScript example

import {
  NativeModules,
} from 'react-native';

const {Appfigurate} = NativeModules;

...

let fontSize = await Appfigurate.nativeValue("fontSize"); // Number

You can customize the minimum and maximum images using the parameter. If restart is true, then the app will be restarted if the property value changes.

You can customize the minimum and maximum images using the parameter. If restart is true, then the app will be restarted if the property value changes.

sliderIcon
sliderIcon
reset
reset
APLConfiguration
reset
reset
APLNativeConfiguration
APLConfiguration
nz.co.electricbolt.appfiguratelibrary.Configuration
APLConfiguration
nz.co.electricbolt.appfiguratelibrary.Configuration
JavaScript's 53 bit limitation
icon
icon