ui-ux-pro-max-cli 2.8.8
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.
- package/README.md +99 -0
- package/assets/data/_sync_all.py +414 -0
- package/assets/data/app-interface.csv +31 -0
- package/assets/data/charts.csv +26 -0
- package/assets/data/colors.csv +162 -0
- package/assets/data/design.csv +1776 -0
- package/assets/data/draft.csv +1779 -0
- package/assets/data/google-fonts.csv +1924 -0
- package/assets/data/icons.csv +106 -0
- package/assets/data/landing.csv +35 -0
- package/assets/data/products.csv +162 -0
- package/assets/data/react-performance.csv +45 -0
- package/assets/data/stacks/angular.csv +51 -0
- package/assets/data/stacks/astro.csv +54 -0
- package/assets/data/stacks/flutter.csv +53 -0
- package/assets/data/stacks/html-tailwind.csv +56 -0
- package/assets/data/stacks/javafx.csv +76 -0
- package/assets/data/stacks/jetpack-compose.csv +53 -0
- package/assets/data/stacks/laravel.csv +51 -0
- package/assets/data/stacks/nextjs.csv +53 -0
- package/assets/data/stacks/nuxt-ui.csv +71 -0
- package/assets/data/stacks/nuxtjs.csv +59 -0
- package/assets/data/stacks/react-native.csv +52 -0
- package/assets/data/stacks/react.csv +54 -0
- package/assets/data/stacks/shadcn.csv +61 -0
- package/assets/data/stacks/svelte.csv +54 -0
- package/assets/data/stacks/swiftui.csv +51 -0
- package/assets/data/stacks/threejs.csv +54 -0
- package/assets/data/stacks/vue.csv +50 -0
- package/assets/data/styles.csv +85 -0
- package/assets/data/typography.csv +74 -0
- package/assets/data/ui-reasoning.csv +162 -0
- package/assets/data/ux-guidelines.csv +100 -0
- package/assets/scripts/core.py +263 -0
- package/assets/scripts/design_system.py +1157 -0
- package/assets/scripts/search.py +114 -0
- package/assets/skills/banner-design/SKILL.md +196 -0
- package/assets/skills/banner-design/references/banner-sizes-and-styles.md +118 -0
- package/assets/skills/brand/SKILL.md +97 -0
- package/assets/skills/brand/references/approval-checklist.md +169 -0
- package/assets/skills/brand/references/asset-organization.md +157 -0
- package/assets/skills/brand/references/brand-guideline-template.md +140 -0
- package/assets/skills/brand/references/color-palette-management.md +186 -0
- package/assets/skills/brand/references/consistency-checklist.md +94 -0
- package/assets/skills/brand/references/logo-usage-rules.md +185 -0
- package/assets/skills/brand/references/messaging-framework.md +85 -0
- package/assets/skills/brand/references/typography-specifications.md +214 -0
- package/assets/skills/brand/references/update.md +118 -0
- package/assets/skills/brand/references/visual-identity.md +96 -0
- package/assets/skills/brand/references/voice-framework.md +88 -0
- package/assets/skills/brand/scripts/extract-colors.cjs +341 -0
- package/assets/skills/brand/scripts/inject-brand-context.cjs +349 -0
- package/assets/skills/brand/scripts/sync-brand-to-tokens.cjs +266 -0
- package/assets/skills/brand/scripts/validate-asset.cjs +387 -0
- package/assets/skills/brand/templates/brand-guidelines-starter.md +275 -0
- package/assets/skills/design/SKILL.md +313 -0
- package/assets/skills/design/data/cip/deliverables.csv +51 -0
- package/assets/skills/design/data/cip/industries.csv +21 -0
- package/assets/skills/design/data/cip/mockup-contexts.csv +21 -0
- package/assets/skills/design/data/cip/styles.csv +21 -0
- package/assets/skills/design/data/icon/styles.csv +16 -0
- package/assets/skills/design/data/logo/colors.csv +56 -0
- package/assets/skills/design/data/logo/industries.csv +56 -0
- package/assets/skills/design/data/logo/styles.csv +56 -0
- package/assets/skills/design/references/banner-sizes-and-styles.md +118 -0
- package/assets/skills/design/references/cip-deliverable-guide.md +95 -0
- package/assets/skills/design/references/cip-design.md +121 -0
- package/assets/skills/design/references/cip-prompt-engineering.md +84 -0
- package/assets/skills/design/references/cip-style-guide.md +68 -0
- package/assets/skills/design/references/design-routing.md +207 -0
- package/assets/skills/design/references/icon-design.md +122 -0
- package/assets/skills/design/references/logo-color-psychology.md +101 -0
- package/assets/skills/design/references/logo-design.md +92 -0
- package/assets/skills/design/references/logo-prompt-engineering.md +158 -0
- package/assets/skills/design/references/logo-style-guide.md +109 -0
- package/assets/skills/design/references/slides-copywriting-formulas.md +84 -0
- package/assets/skills/design/references/slides-create.md +4 -0
- package/assets/skills/design/references/slides-html-template.md +295 -0
- package/assets/skills/design/references/slides-layout-patterns.md +137 -0
- package/assets/skills/design/references/slides-strategies.md +94 -0
- package/assets/skills/design/references/slides.md +42 -0
- package/assets/skills/design/references/social-photos-design.md +329 -0
- package/assets/skills/design/scripts/cip/core.py +215 -0
- package/assets/skills/design/scripts/cip/generate.py +484 -0
- package/assets/skills/design/scripts/cip/render-html.py +424 -0
- package/assets/skills/design/scripts/cip/search.py +127 -0
- package/assets/skills/design/scripts/icon/generate.py +487 -0
- package/assets/skills/design/scripts/logo/core.py +175 -0
- package/assets/skills/design/scripts/logo/generate.py +362 -0
- package/assets/skills/design/scripts/logo/search.py +114 -0
- package/assets/skills/design-system/SKILL.md +244 -0
- package/assets/skills/design-system/data/slide-backgrounds.csv +11 -0
- package/assets/skills/design-system/data/slide-charts.csv +26 -0
- package/assets/skills/design-system/data/slide-color-logic.csv +14 -0
- package/assets/skills/design-system/data/slide-copy.csv +26 -0
- package/assets/skills/design-system/data/slide-layout-logic.csv +16 -0
- package/assets/skills/design-system/data/slide-layouts.csv +26 -0
- package/assets/skills/design-system/data/slide-strategies.csv +16 -0
- package/assets/skills/design-system/data/slide-typography.csv +15 -0
- package/assets/skills/design-system/references/component-specs.md +236 -0
- package/assets/skills/design-system/references/component-tokens.md +214 -0
- package/assets/skills/design-system/references/primitive-tokens.md +203 -0
- package/assets/skills/design-system/references/semantic-tokens.md +215 -0
- package/assets/skills/design-system/references/states-and-variants.md +241 -0
- package/assets/skills/design-system/references/tailwind-integration.md +251 -0
- package/assets/skills/design-system/references/token-architecture.md +224 -0
- package/assets/skills/design-system/scripts/embed-tokens.cjs +99 -0
- package/assets/skills/design-system/scripts/fetch-background.py +317 -0
- package/assets/skills/design-system/scripts/generate-slide.py +770 -0
- package/assets/skills/design-system/scripts/generate-tokens.cjs +205 -0
- package/assets/skills/design-system/scripts/html-token-validator.py +327 -0
- package/assets/skills/design-system/scripts/search-slides.py +218 -0
- package/assets/skills/design-system/scripts/slide-token-validator.py +35 -0
- package/assets/skills/design-system/scripts/slide_search_core.py +453 -0
- package/assets/skills/design-system/scripts/validate-tokens.cjs +251 -0
- package/assets/skills/design-system/templates/design-tokens-starter.json +143 -0
- package/assets/skills/slides/SKILL.md +40 -0
- package/assets/skills/slides/references/copywriting-formulas.md +84 -0
- package/assets/skills/slides/references/create.md +4 -0
- package/assets/skills/slides/references/html-template.md +295 -0
- package/assets/skills/slides/references/layout-patterns.md +137 -0
- package/assets/skills/slides/references/slide-strategies.md +94 -0
- package/assets/skills/ui-styling/LICENSE.txt +202 -0
- package/assets/skills/ui-styling/SKILL.md +324 -0
- package/assets/skills/ui-styling/references/canvas-design-system.md +320 -0
- package/assets/skills/ui-styling/references/shadcn-accessibility.md +471 -0
- package/assets/skills/ui-styling/references/shadcn-components.md +424 -0
- package/assets/skills/ui-styling/references/shadcn-theming.md +373 -0
- package/assets/skills/ui-styling/references/tailwind-customization.md +483 -0
- package/assets/skills/ui-styling/references/tailwind-responsive.md +382 -0
- package/assets/skills/ui-styling/references/tailwind-utilities.md +455 -0
- package/assets/skills/ui-styling/scripts/requirements.txt +17 -0
- package/assets/skills/ui-styling/scripts/shadcn_add.py +308 -0
- package/assets/skills/ui-styling/scripts/tailwind_config_gen.py +473 -0
- package/assets/skills/ui-styling/scripts/tests/coverage-ui.json +1 -0
- package/assets/skills/ui-styling/scripts/tests/requirements.txt +3 -0
- package/assets/skills/ui-styling/scripts/tests/test_shadcn_add.py +266 -0
- package/assets/skills/ui-styling/scripts/tests/test_tailwind_config_gen.py +336 -0
- package/assets/templates/base/quick-reference.md +297 -0
- package/assets/templates/base/skill-content.md +368 -0
- package/assets/templates/platforms/agent.json +21 -0
- package/assets/templates/platforms/augment.json +18 -0
- package/assets/templates/platforms/claude.json +21 -0
- package/assets/templates/platforms/codebuddy.json +21 -0
- package/assets/templates/platforms/codex.json +21 -0
- package/assets/templates/platforms/continue.json +21 -0
- package/assets/templates/platforms/copilot.json +21 -0
- package/assets/templates/platforms/cursor.json +21 -0
- package/assets/templates/platforms/droid.json +21 -0
- package/assets/templates/platforms/gemini.json +21 -0
- package/assets/templates/platforms/kilocode.json +21 -0
- package/assets/templates/platforms/kiro.json +21 -0
- package/assets/templates/platforms/opencode.json +21 -0
- package/assets/templates/platforms/qoder.json +21 -0
- package/assets/templates/platforms/roocode.json +21 -0
- package/assets/templates/platforms/trae.json +21 -0
- package/assets/templates/platforms/warp.json +18 -0
- package/assets/templates/platforms/windsurf.json +21 -0
- package/dist/index.js +10630 -0
- package/package.json +51 -0
|
@@ -0,0 +1,218 @@
|
|
|
1
|
+
#!/usr/bin/env python3
|
|
2
|
+
# -*- coding: utf-8 -*-
|
|
3
|
+
"""
|
|
4
|
+
Slide Search CLI - Search slide design databases for strategies, layouts, copy, and charts
|
|
5
|
+
"""
|
|
6
|
+
|
|
7
|
+
import sys
|
|
8
|
+
import json
|
|
9
|
+
import argparse
|
|
10
|
+
from slide_search_core import (
|
|
11
|
+
search, search_all, AVAILABLE_DOMAINS,
|
|
12
|
+
search_with_context, get_layout_for_goal, get_typography_for_slide,
|
|
13
|
+
get_color_for_emotion, get_background_config
|
|
14
|
+
)
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
def format_result(result, domain):
|
|
18
|
+
"""Format a single search result for display"""
|
|
19
|
+
output = []
|
|
20
|
+
|
|
21
|
+
if domain == "strategy":
|
|
22
|
+
output.append(f"**{result.get('strategy_name', 'N/A')}**")
|
|
23
|
+
output.append(f" Slides: {result.get('slide_count', 'N/A')}")
|
|
24
|
+
output.append(f" Structure: {result.get('structure', 'N/A')}")
|
|
25
|
+
output.append(f" Goal: {result.get('goal', 'N/A')}")
|
|
26
|
+
output.append(f" Audience: {result.get('audience', 'N/A')}")
|
|
27
|
+
output.append(f" Tone: {result.get('tone', 'N/A')}")
|
|
28
|
+
output.append(f" Arc: {result.get('narrative_arc', 'N/A')}")
|
|
29
|
+
output.append(f" Source: {result.get('sources', 'N/A')}")
|
|
30
|
+
|
|
31
|
+
elif domain == "layout":
|
|
32
|
+
output.append(f"**{result.get('layout_name', 'N/A')}**")
|
|
33
|
+
output.append(f" Use case: {result.get('use_case', 'N/A')}")
|
|
34
|
+
output.append(f" Zones: {result.get('content_zones', 'N/A')}")
|
|
35
|
+
output.append(f" Visual weight: {result.get('visual_weight', 'N/A')}")
|
|
36
|
+
output.append(f" CTA: {result.get('cta_placement', 'N/A')}")
|
|
37
|
+
output.append(f" Recommended: {result.get('recommended_for', 'N/A')}")
|
|
38
|
+
output.append(f" Avoid: {result.get('avoid_for', 'N/A')}")
|
|
39
|
+
output.append(f" CSS: {result.get('css_structure', 'N/A')}")
|
|
40
|
+
|
|
41
|
+
elif domain == "copy":
|
|
42
|
+
output.append(f"**{result.get('formula_name', 'N/A')}**")
|
|
43
|
+
output.append(f" Components: {result.get('components', 'N/A')}")
|
|
44
|
+
output.append(f" Use case: {result.get('use_case', 'N/A')}")
|
|
45
|
+
output.append(f" Template: {result.get('example_template', 'N/A')}")
|
|
46
|
+
output.append(f" Emotion: {result.get('emotion_trigger', 'N/A')}")
|
|
47
|
+
output.append(f" Slide type: {result.get('slide_type', 'N/A')}")
|
|
48
|
+
output.append(f" Source: {result.get('source', 'N/A')}")
|
|
49
|
+
|
|
50
|
+
elif domain == "chart":
|
|
51
|
+
output.append(f"**{result.get('chart_type', 'N/A')}**")
|
|
52
|
+
output.append(f" Best for: {result.get('best_for', 'N/A')}")
|
|
53
|
+
output.append(f" Data type: {result.get('data_type', 'N/A')}")
|
|
54
|
+
output.append(f" When to use: {result.get('when_to_use', 'N/A')}")
|
|
55
|
+
output.append(f" When to avoid: {result.get('when_to_avoid', 'N/A')}")
|
|
56
|
+
output.append(f" Max categories: {result.get('max_categories', 'N/A')}")
|
|
57
|
+
output.append(f" Slide context: {result.get('slide_context', 'N/A')}")
|
|
58
|
+
output.append(f" CSS: {result.get('css_implementation', 'N/A')}")
|
|
59
|
+
output.append(f" Accessibility: {result.get('accessibility_notes', 'N/A')}")
|
|
60
|
+
|
|
61
|
+
return "\n".join(output)
|
|
62
|
+
|
|
63
|
+
|
|
64
|
+
def format_context(context):
|
|
65
|
+
"""Format contextual recommendations for display."""
|
|
66
|
+
output = []
|
|
67
|
+
output.append(f"\n=== CONTEXTUAL RECOMMENDATIONS ===")
|
|
68
|
+
output.append(f"Inferred Goal: {context.get('inferred_goal', 'N/A')}")
|
|
69
|
+
output.append(f"Position: Slide {context.get('slide_position')} of {context.get('total_slides')}")
|
|
70
|
+
|
|
71
|
+
if context.get('recommended_layout'):
|
|
72
|
+
output.append(f"\n📐 Layout: {context['recommended_layout']}")
|
|
73
|
+
output.append(f" Direction: {context.get('layout_direction', 'N/A')}")
|
|
74
|
+
output.append(f" Visual Weight: {context.get('visual_weight', 'N/A')}")
|
|
75
|
+
|
|
76
|
+
if context.get('typography'):
|
|
77
|
+
typo = context['typography']
|
|
78
|
+
output.append(f"\n📝 Typography:")
|
|
79
|
+
output.append(f" Primary: {typo.get('primary_size', 'N/A')}")
|
|
80
|
+
output.append(f" Secondary: {typo.get('secondary_size', 'N/A')}")
|
|
81
|
+
output.append(f" Contrast: {typo.get('weight_contrast', 'N/A')}")
|
|
82
|
+
|
|
83
|
+
if context.get('color_treatment'):
|
|
84
|
+
color = context['color_treatment']
|
|
85
|
+
output.append(f"\n🎨 Color Treatment:")
|
|
86
|
+
output.append(f" Background: {color.get('background', 'N/A')}")
|
|
87
|
+
output.append(f" Text: {color.get('text_color', 'N/A')}")
|
|
88
|
+
output.append(f" Accent: {color.get('accent_usage', 'N/A')}")
|
|
89
|
+
|
|
90
|
+
if context.get('should_break_pattern'):
|
|
91
|
+
output.append(f"\n⚡ Pattern Break: YES (use contrasting layout)")
|
|
92
|
+
|
|
93
|
+
if context.get('should_use_full_bleed'):
|
|
94
|
+
output.append(f"\n🖼️ Full Bleed: Recommended for emotional impact")
|
|
95
|
+
|
|
96
|
+
if context.get('use_background_image') and context.get('background'):
|
|
97
|
+
bg = context['background']
|
|
98
|
+
output.append(f"\n📸 Background Image:")
|
|
99
|
+
output.append(f" Category: {bg.get('image_category', 'N/A')}")
|
|
100
|
+
output.append(f" Overlay: {bg.get('overlay_style', 'N/A')}")
|
|
101
|
+
output.append(f" Keywords: {bg.get('search_keywords', 'N/A')}")
|
|
102
|
+
|
|
103
|
+
output.append(f"\n✨ Animation: {context.get('animation_class', 'animate-fade-up')}")
|
|
104
|
+
|
|
105
|
+
return "\n".join(output)
|
|
106
|
+
|
|
107
|
+
|
|
108
|
+
def main():
|
|
109
|
+
parser = argparse.ArgumentParser(
|
|
110
|
+
description="Search slide design databases",
|
|
111
|
+
formatter_class=argparse.RawDescriptionHelpFormatter,
|
|
112
|
+
epilog="""
|
|
113
|
+
Examples:
|
|
114
|
+
search-slides.py "investor pitch" # Auto-detect domain (strategy)
|
|
115
|
+
search-slides.py "funnel conversion" -d chart
|
|
116
|
+
search-slides.py "headline hook" -d copy
|
|
117
|
+
search-slides.py "two column" -d layout
|
|
118
|
+
search-slides.py "startup funding" --all # Search all domains
|
|
119
|
+
search-slides.py "metrics dashboard" --json # JSON output
|
|
120
|
+
|
|
121
|
+
Contextual Search (Premium System):
|
|
122
|
+
search-slides.py "problem slide" --context --position 2 --total 9
|
|
123
|
+
search-slides.py "cta" --context --position 9 --total 9 --prev-emotion frustration
|
|
124
|
+
"""
|
|
125
|
+
)
|
|
126
|
+
|
|
127
|
+
parser.add_argument("query", help="Search query")
|
|
128
|
+
parser.add_argument("-d", "--domain", choices=AVAILABLE_DOMAINS,
|
|
129
|
+
help="Specific domain to search (auto-detected if not specified)")
|
|
130
|
+
parser.add_argument("-n", "--max-results", type=int, default=3,
|
|
131
|
+
help="Maximum results to return (default: 3)")
|
|
132
|
+
parser.add_argument("--all", action="store_true",
|
|
133
|
+
help="Search across all domains")
|
|
134
|
+
parser.add_argument("--json", action="store_true",
|
|
135
|
+
help="Output as JSON")
|
|
136
|
+
|
|
137
|
+
# Contextual search options
|
|
138
|
+
parser.add_argument("--context", action="store_true",
|
|
139
|
+
help="Use contextual search with layout/typography/color recommendations")
|
|
140
|
+
parser.add_argument("--position", type=int, default=1,
|
|
141
|
+
help="Slide position in deck (1-based, default: 1)")
|
|
142
|
+
parser.add_argument("--total", type=int, default=9,
|
|
143
|
+
help="Total slides in deck (default: 9)")
|
|
144
|
+
parser.add_argument("--prev-emotion", type=str, default=None,
|
|
145
|
+
help="Previous slide's emotion for contrast calculation")
|
|
146
|
+
|
|
147
|
+
args = parser.parse_args()
|
|
148
|
+
|
|
149
|
+
# Contextual search mode
|
|
150
|
+
if args.context:
|
|
151
|
+
result = search_with_context(
|
|
152
|
+
args.query,
|
|
153
|
+
slide_position=args.position,
|
|
154
|
+
total_slides=args.total,
|
|
155
|
+
previous_emotion=args.prev_emotion
|
|
156
|
+
)
|
|
157
|
+
|
|
158
|
+
if args.json:
|
|
159
|
+
print(json.dumps(result, indent=2))
|
|
160
|
+
else:
|
|
161
|
+
print(format_context(result['context']))
|
|
162
|
+
|
|
163
|
+
# Also show base search results
|
|
164
|
+
if result.get('base_results'):
|
|
165
|
+
print("\n\n=== RELATED SEARCH RESULTS ===")
|
|
166
|
+
for domain, data in result['base_results'].items():
|
|
167
|
+
print(f"\n--- {domain.upper()} ---")
|
|
168
|
+
for item in data['results']:
|
|
169
|
+
print(format_result(item, domain))
|
|
170
|
+
print()
|
|
171
|
+
return
|
|
172
|
+
|
|
173
|
+
if args.all:
|
|
174
|
+
results = search_all(args.query, args.max_results)
|
|
175
|
+
|
|
176
|
+
if args.json:
|
|
177
|
+
print(json.dumps(results, indent=2))
|
|
178
|
+
else:
|
|
179
|
+
if not results:
|
|
180
|
+
print(f"No results found for: {args.query}")
|
|
181
|
+
return
|
|
182
|
+
|
|
183
|
+
for domain, data in results.items():
|
|
184
|
+
print(f"\n=== {domain.upper()} ===")
|
|
185
|
+
print(f"File: {data['file']}")
|
|
186
|
+
print(f"Results: {data['count']}")
|
|
187
|
+
print()
|
|
188
|
+
for result in data['results']:
|
|
189
|
+
print(format_result(result, domain))
|
|
190
|
+
print()
|
|
191
|
+
else:
|
|
192
|
+
result = search(args.query, args.domain, args.max_results)
|
|
193
|
+
|
|
194
|
+
if args.json:
|
|
195
|
+
print(json.dumps(result, indent=2))
|
|
196
|
+
else:
|
|
197
|
+
if result.get("error"):
|
|
198
|
+
print(f"Error: {result['error']}")
|
|
199
|
+
return
|
|
200
|
+
|
|
201
|
+
print(f"Domain: {result['domain']}")
|
|
202
|
+
print(f"Query: {result['query']}")
|
|
203
|
+
print(f"File: {result['file']}")
|
|
204
|
+
print(f"Results: {result['count']}")
|
|
205
|
+
print()
|
|
206
|
+
|
|
207
|
+
if result['count'] == 0:
|
|
208
|
+
print("No matching results found.")
|
|
209
|
+
return
|
|
210
|
+
|
|
211
|
+
for i, item in enumerate(result['results'], 1):
|
|
212
|
+
print(f"--- Result {i} ---")
|
|
213
|
+
print(format_result(item, result['domain']))
|
|
214
|
+
print()
|
|
215
|
+
|
|
216
|
+
|
|
217
|
+
if __name__ == "__main__":
|
|
218
|
+
main()
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
#!/usr/bin/env python3
|
|
2
|
+
"""
|
|
3
|
+
Slide Token Validator (Legacy Wrapper)
|
|
4
|
+
Now delegates to html-token-validator.py for unified HTML validation.
|
|
5
|
+
|
|
6
|
+
For new usage, prefer:
|
|
7
|
+
python html-token-validator.py --type slides
|
|
8
|
+
python html-token-validator.py --type infographics
|
|
9
|
+
python html-token-validator.py # All HTML assets
|
|
10
|
+
"""
|
|
11
|
+
|
|
12
|
+
import sys
|
|
13
|
+
import subprocess
|
|
14
|
+
from pathlib import Path
|
|
15
|
+
|
|
16
|
+
SCRIPT_DIR = Path(__file__).parent
|
|
17
|
+
UNIFIED_VALIDATOR = SCRIPT_DIR / 'html-token-validator.py'
|
|
18
|
+
|
|
19
|
+
|
|
20
|
+
def main():
|
|
21
|
+
"""Delegate to unified html-token-validator.py with --type slides."""
|
|
22
|
+
args = sys.argv[1:]
|
|
23
|
+
|
|
24
|
+
# If no files specified, default to slides type
|
|
25
|
+
if not args or all(arg.startswith('-') for arg in args):
|
|
26
|
+
cmd = [sys.executable, str(UNIFIED_VALIDATOR), '--type', 'slides'] + args
|
|
27
|
+
else:
|
|
28
|
+
cmd = [sys.executable, str(UNIFIED_VALIDATOR)] + args
|
|
29
|
+
|
|
30
|
+
result = subprocess.run(cmd)
|
|
31
|
+
sys.exit(result.returncode)
|
|
32
|
+
|
|
33
|
+
|
|
34
|
+
if __name__ == '__main__':
|
|
35
|
+
main()
|