mtcli-renko 1.0.0.dev0__tar.gz → 1.0.0.dev1__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: mtcli-renko
3
- Version: 1.0.0.dev0
3
+ Version: 1.0.0.dev1
4
4
  Summary: Plugin do mtcli
5
5
  License-Expression: GPL-3.0
6
6
  License-File: LICENSE
@@ -0,0 +1,76 @@
1
+ """
2
+ Comando CLI para geração de gráfico Renko.
3
+ """
4
+
5
+ import click
6
+
7
+ from ..controllers.renko_controller import RenkoController
8
+ from ..views.renko_view import exibir_renko
9
+ from ..domain.timeframe import Timeframe
10
+ from mtcli.logger import setup_logger
11
+ from ..conf import (
12
+ SYMBOL,
13
+ BRICK,
14
+ PERIOD,
15
+ BARS
16
+ )
17
+
18
+
19
+ log = setup_logger(__name__)
20
+
21
+
22
+ @click.command()
23
+ @click.version_option(package_name="mtcli-renko")
24
+ @click.option(
25
+ "--symbol",
26
+ "-s",
27
+ default=SYMBOL,
28
+ show_default=True,
29
+ help="Ativo (ex: WINJ26)",
30
+ )
31
+ @click.option(
32
+ "--brick",
33
+ "-b",
34
+ default=BRICK,
35
+ show_default=True,
36
+ type=float,
37
+ help="Tamanho do brick em pontos",
38
+ )
39
+ @click.option(
40
+ "--timeframe",
41
+ "-t",
42
+ default=PERIOD,
43
+ show_default=True,
44
+ help=f"Timeframe ({', '.join(Timeframe.valid_labels())})",
45
+ )
46
+ @click.option(
47
+ "--bars",
48
+ "-n",
49
+ default=BARS,
50
+ show_default=True,
51
+ help="Quantidade de candles para cálculo",
52
+ )
53
+ def renko(symbol, brick, timeframe, bars):
54
+ """
55
+ Gera gráfico Renko em modo texto (screen reader friendly).
56
+ """
57
+
58
+ try:
59
+ tf_enum = Timeframe.from_string(timeframe)
60
+ except ValueError as e:
61
+ raise click.BadParameter(str(e))
62
+
63
+ log.info(
64
+ f"[Renko CLI] symbol={symbol} | brick={brick} | "
65
+ f"timeframe={tf_enum.label} | bars={bars}"
66
+ )
67
+
68
+ controller = RenkoController(
69
+ symbol,
70
+ brick,
71
+ tf_enum.mt5_const,
72
+ bars,
73
+ )
74
+
75
+ bricks = controller.executar()
76
+ exibir_renko(bricks)
@@ -53,10 +53,15 @@ SYMBOL = os.getenv(
53
53
 
54
54
  BRICK = float(os.getenv(
55
55
  "BRICK",
56
- _get_config_value("RENKO", "brick", 5)
56
+ _get_config_value("RENKO", "brick", 50)
57
57
  ))
58
58
 
59
- INTERVAL = float(os.getenv(
60
- "INTERVAL",
61
- _get_config_value("delta", "interval", 0.5)
59
+ PERIOD = os.getenv(
60
+ "PERIOD",
61
+ _get_config_value("RENKO", "period", "M5")
62
+ )
63
+
64
+ BARS = int(os.getenv(
65
+ "BARS",
66
+ _get_config_value("RENKO", "bars", 500)
62
67
  ))
@@ -0,0 +1,87 @@
1
+ """
2
+ Enum de Timeframes suportados pelo MTCLI Renko.
3
+
4
+ Fornece:
5
+ - Conversão amigável (m5, 5m, h1, 1h)
6
+ - Mapeamento para constante MT5
7
+ - Lista de valores válidos para CLI
8
+ """
9
+
10
+ from enum import Enum
11
+ import MetaTrader5 as mt5
12
+
13
+
14
+ class Timeframe(Enum):
15
+ """
16
+ Representa timeframes suportados pelo MT5.
17
+ """
18
+
19
+ M1 = ("m1", mt5.TIMEFRAME_M1)
20
+ M2 = ("m2", mt5.TIMEFRAME_M2)
21
+ M3 = ("m3", mt5.TIMEFRAME_M3)
22
+ M4 = ("m4", mt5.TIMEFRAME_M4)
23
+ M5 = ("m5", mt5.TIMEFRAME_M5)
24
+ M10 = ("m10", mt5.TIMEFRAME_M10)
25
+ M15 = ("m15", mt5.TIMEFRAME_M15)
26
+ M30 = ("m30", mt5.TIMEFRAME_M30)
27
+
28
+ H1 = ("h1", mt5.TIMEFRAME_H1)
29
+ H2 = ("h2", mt5.TIMEFRAME_H2)
30
+ H3 = ("h3", mt5.TIMEFRAME_H3)
31
+ H4 = ("h4", mt5.TIMEFRAME_H4)
32
+ H6 = ("h6", mt5.TIMEFRAME_H6)
33
+ H8 = ("h8", mt5.TIMEFRAME_H8)
34
+ H12 = ("h12", mt5.TIMEFRAME_H12)
35
+
36
+ D1 = ("d1", mt5.TIMEFRAME_D1)
37
+ W1 = ("w1", mt5.TIMEFRAME_W1)
38
+ MN1 = ("mn1", mt5.TIMEFRAME_MN1)
39
+
40
+ def __init__(self, label: str, mt5_const: int):
41
+ self.label = label
42
+ self.mt5_const = mt5_const
43
+
44
+ @classmethod
45
+ def from_string(cls, value: str) -> "Timeframe":
46
+ """
47
+ Converte string amigável para Enum Timeframe.
48
+
49
+ Aceita:
50
+ m5, 5m
51
+ h1, 1h
52
+ d1, 1d
53
+ """
54
+
55
+ value = value.strip().lower()
56
+
57
+ # Aliases humanos
58
+ aliases = {
59
+ "1m": "m1",
60
+ "5m": "m5",
61
+ "15m": "m15",
62
+ "30m": "m30",
63
+ "1h": "h1",
64
+ "4h": "h4",
65
+ "1d": "d1",
66
+ "1w": "w1",
67
+ "1mo": "mn1",
68
+ }
69
+
70
+ if value in aliases:
71
+ value = aliases[value]
72
+
73
+ for tf in cls:
74
+ if tf.label == value:
75
+ return tf
76
+
77
+ raise ValueError(
78
+ f"Timeframe inválido: {value}. "
79
+ f"Use: {', '.join(cls.valid_labels())}"
80
+ )
81
+
82
+ @classmethod
83
+ def valid_labels(cls):
84
+ """
85
+ Retorna lista de labels válidos.
86
+ """
87
+ return [tf.label for tf in cls]
File without changes
@@ -1,6 +1,6 @@
1
1
  [project]
2
2
  name = "mtcli-renko"
3
- version = "1.0.0.dev0"
3
+ version = "1.0.0.dev1"
4
4
  description = "Plugin do mtcli"
5
5
  authors = [
6
6
  {name = "Valmir França",email = "vfranca3@gmail.com"}
@@ -1,24 +0,0 @@
1
- """
2
- Comando CLI para geração de gráfico Renko.
3
- """
4
-
5
- import click
6
- from ..controllers.renko_controller import RenkoController
7
- from ..views.renko_view import exibir_renko
8
- import MetaTrader5 as mt5
9
-
10
-
11
- @click.command()
12
- @click.option("--symbol", "-s", required=True)
13
- @click.option("--brick", "-b", required=True, type=float)
14
- @click.option("--timeframe", "-t", default=mt5.TIMEFRAME_M5)
15
- @click.option("--bars", "-n", default=500)
16
- def renko(symbol, brick, timeframe, bars):
17
- """
18
- Gera gráfico Renko em modo texto.
19
- """
20
-
21
- controller = RenkoController(symbol, brick, timeframe, bars)
22
- bricks = controller.executar()
23
-
24
- exibir_renko(bricks)