Lean  $LEAN_TAG$
TradingLiabilitiesBalanceSheet.cs
1 /*
2  * QUANTCONNECT.COM - Democratizing Finance, Empowering Individuals.
3  * Lean Algorithmic Trading Engine v2.0. Copyright 2023 QuantConnect Corporation.
4  *
5  * Licensed under the Apache License, Version 2.0 (the "License");
6  * you may not use this file except in compliance with the License.
7  * You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0
8  *
9  * Unless required by applicable law or agreed to in writing, software
10  * distributed under the License is distributed on an "AS IS" BASIS,
11  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12  * See the License for the specific language governing permissions and
13  * limitations under the License.
14  *
15 */
16 
17 using System;
18 using System.Linq;
19 using Python.Runtime;
20 using Newtonsoft.Json;
21 using System.Collections.Generic;
23 
25 {
26  /// <summary>
27  /// The carrying amount of liabilities as of the balance sheet date that pertain to principal and customer trading transactions, or which may be incurred with the objective of generating a profit from short-term fluctuations in price as part of an entity's market-making, hedging and proprietary trading. Examples include short positions in securities, derivatives and commodities, obligations under repurchase agreements, and securities borrowed arrangements.
28  /// </summary>
30  {
31  /// <summary>
32  /// The default period
33  /// </summary>
34  protected override string DefaultPeriod => "TwelveMonths";
35 
36  /// <summary>
37  /// Gets/sets the ThreeMonths period value for the field
38  /// </summary>
39  [JsonProperty("3M")]
40  public double ThreeMonths => FundamentalService.Get<double>(TimeProvider.GetUtcNow(), SecurityIdentifier, FundamentalProperty.FinancialStatements_BalanceSheet_TradingLiabilities_ThreeMonths);
41 
42  /// <summary>
43  /// Gets/sets the TwelveMonths period value for the field
44  /// </summary>
45  [JsonProperty("12M")]
46  public double TwelveMonths => FundamentalService.Get<double>(TimeProvider.GetUtcNow(), SecurityIdentifier, FundamentalProperty.FinancialStatements_BalanceSheet_TradingLiabilities_TwelveMonths);
47 
48  /// <summary>
49  /// Returns true if the field contains a value for the default period
50  /// </summary>
51  public override bool HasValue => !BaseFundamentalDataProvider.IsNone(typeof(double), FundamentalService.Get<double>(TimeProvider.GetUtcNow(), SecurityIdentifier, FundamentalProperty.FinancialStatements_BalanceSheet_TradingLiabilities_TwelveMonths));
52 
53  /// <summary>
54  /// Returns the default value for the field
55  /// </summary>
56  public override double Value
57  {
58  get
59  {
60  var defaultValue = FundamentalService.Get<double>(TimeProvider.GetUtcNow(), SecurityIdentifier, FundamentalProperty.FinancialStatements_BalanceSheet_TradingLiabilities_TwelveMonths);
61  if (!BaseFundamentalDataProvider.IsNone(typeof(double), defaultValue))
62  {
63  return defaultValue;
64  }
65  return base.Value;
66  }
67  }
68 
69  /// <summary>
70  /// Gets a dictionary of period names and values for the field
71  /// </summary>
72  /// <returns>The dictionary of period names and values</returns>
73  public override IReadOnlyDictionary<string, double> GetPeriodValues()
74  {
75  var result = new Dictionary<string, double>();
76  foreach (var kvp in new[] { new Tuple<string, double>("3M",ThreeMonths), new Tuple<string, double>("12M",TwelveMonths) })
77  {
78  if(!BaseFundamentalDataProvider.IsNone(typeof(double), kvp.Item2))
79  {
80  result[kvp.Item1] = kvp.Item2;
81  }
82  }
83  return result;
84  }
85 
86  /// <summary>
87  /// Gets the value of the field for the requested period
88  /// </summary>
89  /// <param name="period">The requested period</param>
90  /// <returns>The value for the period</returns>
91  public override double GetPeriodValue(string period) => FundamentalService.Get<double>(TimeProvider.GetUtcNow(), SecurityIdentifier, Enum.Parse<FundamentalProperty>($"FinancialStatements_BalanceSheet_TradingLiabilities_{ConvertPeriod(period)}"));
92 
93  /// <summary>
94  /// Creates a new empty instance
95  /// </summary>
97  {
98  }
99 
100  /// <summary>
101  /// Creates a new instance for the given time and security
102  /// </summary>
103  public TradingLiabilitiesBalanceSheet(ITimeProvider timeProvider, SecurityIdentifier securityIdentifier) : base(timeProvider, securityIdentifier)
104  {
105  }
106  }
107 }