MilanM commited on
Commit
a628b62
·
verified ·
1 Parent(s): 58434e5

Update pdf_generator.py

Browse files
Files changed (1) hide show
  1. pdf_generator.py +23 -22
pdf_generator.py CHANGED
@@ -37,13 +37,13 @@ class SliderFlowable(Flowable):
37
  drawing.add(String(0, 60, self.name, fontSize=12, fillColor=colors.HexColor("#26004d")))
38
 
39
  # Add range labels
40
- min_str = f"{self.min_val:.1f}%" if self.is_percentage else f"{self.min_val:.1f}"
41
- max_str = f"{self.max_val:.1f}%" if self.is_percentage else f"{self.max_val:.1f}"
42
  drawing.add(String(40, 10, min_str, fontSize=10, fillColor=colors.HexColor("#26004d")))
43
  drawing.add(String(340, 10, max_str, fontSize=10, fillColor=colors.HexColor("#26004d")))
44
 
45
  # Add value label
46
- value_str = f"{self.value:.1f}%" if self.is_percentage else f"{self.value:.1f}"
47
  drawing.add(String(value_width - 20, 55, value_str, fontSize=10, fillColor=colors.HexColor("#26004d")))
48
 
49
  # Add value marker
@@ -51,6 +51,14 @@ class SliderFlowable(Flowable):
51
 
52
  drawing.drawOn(self.canv, 0, 0)
53
 
 
 
 
 
 
 
 
 
54
  def create_styles():
55
  styles = getSampleStyleSheet()
56
  styles['Title'].fontName = 'Helvetica-Bold'
@@ -146,40 +154,33 @@ def process_quantitative_criteria(answer, styles):
146
  parsed = parse_quantitative_criteria(line)
147
  if parsed:
148
  name, value, min_val, max_val, is_percentage = parsed
149
- if is_percentage:
150
- slider = SliderFlowable(name, value*100, min_val*100, max_val*100, is_percentage=True)
151
- else:
152
- slider = SliderFlowable(name, value, min_val, max_val, is_percentage=False)
153
  story.append(slider)
154
  return story
155
 
156
  def parse_quantitative_criteria(input_string):
157
- # Match both "Name: value [min-max]" and "Name [min-max]" formats
158
- match = re.match(r'(.+?)(?:\s*:\s*([-+]?(?:\d*\.*\d+)(?:%)?))?\s*\[([-+]?(?:\d*\.*\d+)(?:%)?)\s*-\s*([-+]?(?:\d*\.*\d+)(?:%)?)?\]', input_string)
159
  if match:
160
  name, value, min_val, max_val = match.groups()
161
  name = name.strip()
162
 
163
- # Handle the case where value is None
164
- if value is None:
165
- value = 0 # or you can raise an error, depending on your requirements
166
-
167
  # Handle percentage inputs
168
- is_percentage = '%' in str(value) or '%' in min_val or '%' in max_val
169
- value = float(str(value).rstrip('%'))
170
-
171
- min_val = float(min_val.rstrip('%'))
172
- max_val = float(max_val.rstrip('%'))
173
 
 
174
  if is_percentage:
175
- value /= 100
176
- value = int(value)
177
- min_val = int(min_val)
178
- max_val = int(max_val)
179
  else:
180
  value = float(value)
181
  min_val = float(min_val)
182
  max_val = float(max_val)
183
 
 
 
 
 
184
  return name, value, min_val, max_val, is_percentage
185
  return None
 
37
  drawing.add(String(0, 60, self.name, fontSize=12, fillColor=colors.HexColor("#26004d")))
38
 
39
  # Add range labels
40
+ min_str = self.format_value(self.min_val)
41
+ max_str = self.format_value(self.max_val)
42
  drawing.add(String(40, 10, min_str, fontSize=10, fillColor=colors.HexColor("#26004d")))
43
  drawing.add(String(340, 10, max_str, fontSize=10, fillColor=colors.HexColor("#26004d")))
44
 
45
  # Add value label
46
+ value_str = self.format_value(self.value)
47
  drawing.add(String(value_width - 20, 55, value_str, fontSize=10, fillColor=colors.HexColor("#26004d")))
48
 
49
  # Add value marker
 
51
 
52
  drawing.drawOn(self.canv, 0, 0)
53
 
54
+ def format_value(self, val):
55
+ if self.is_percentage:
56
+ return f"{val:.1f}%"
57
+ elif isinstance(val, int):
58
+ return f"{val}"
59
+ else:
60
+ return f"{val:.2f}"
61
+
62
  def create_styles():
63
  styles = getSampleStyleSheet()
64
  styles['Title'].fontName = 'Helvetica-Bold'
 
154
  parsed = parse_quantitative_criteria(line)
155
  if parsed:
156
  name, value, min_val, max_val, is_percentage = parsed
157
+ slider = SliderFlowable(name, value, min_val, max_val, is_percentage)
 
 
 
158
  story.append(slider)
159
  return story
160
 
161
  def parse_quantitative_criteria(input_string):
162
+ # Match "Name: value [min-max]" format
163
+ match = re.match(r'(.+?):\s*([-+]?(?:\d*\.*\d+)(?:%)?)\s*\[([-+]?(?:\d*\.*\d+)(?:%)?)\s*-\s*([-+]?(?:\d*\.*\d+)(?:%)?)?\]', input_string)
164
  if match:
165
  name, value, min_val, max_val = match.groups()
166
  name = name.strip()
167
 
 
 
 
 
168
  # Handle percentage inputs
169
+ is_percentage = '%' in value or '%' in min_val or '%' in max_val
 
 
 
 
170
 
171
+ # Convert values to appropriate types
172
  if is_percentage:
173
+ value = float(value.rstrip('%'))
174
+ min_val = float(min_val.rstrip('%'))
175
+ max_val = float(max_val.rstrip('%'))
 
176
  else:
177
  value = float(value)
178
  min_val = float(min_val)
179
  max_val = float(max_val)
180
 
181
+ # Convert to int if all values are whole numbers
182
+ if all(v.is_integer() for v in [value, min_val, max_val]):
183
+ value, min_val, max_val = int(value), int(min_val), int(max_val)
184
+
185
  return name, value, min_val, max_val, is_percentage
186
  return None