1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
// This file is part of ICU4X. For terms of use, please see the file
// called LICENSE at the top level of the ICU4X source tree
// (online at: https://github.com/unicode-org/icu4x/blob/main/LICENSE ).

//! Options for [`PercentFormatter`](crate::dimension::percent::formatter::PercentFormatter).

/// A collection of configuration options that determine the formatting behavior of
/// [`PercentFormatter`](crate::dimension::percent::formatter::PercentFormatter).
#[derive(Copy, Debug, Eq, PartialEq, Clone, Default)]
#[non_exhaustive]
pub struct PercentFormatterOptions {
    /// The display of the percent format.
    pub display: Display,
}

impl From<Display> for PercentFormatterOptions {
    fn from(display: Display) -> Self {
        Self { display }
    }
}

#[derive(Debug, Eq, PartialEq, Clone, Copy)]
#[non_exhaustive]
pub enum Display {
    /// Format the Percent to display with the standard formatting for the locale.
    ///
    /// For example 123 -> 123% in en-US.
    Standard,
    /// Format the Percent to display as an approximate value.
    ///
    /// For example 123 -> ~123% in en-US.
    Approximate,
    /// Format the Percent to display with an explicit sign.
    ///
    /// For example 123 -> +123% in en-US.
    ExplicitSign,
}

impl Default for Display {
    fn default() -> Self {
        Self::Standard
    }
}