@gallop.software/canon 1.0.0 → 2.0.0

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/dist/index.js CHANGED
@@ -1,109 +1,95 @@
1
- "use strict";
2
1
  /**
3
2
  * @gallop/canon
4
3
  *
5
4
  * Gallop Enterprise Architecture Canon
6
5
  * Versioned, AI-compatible, auditable web architecture patterns
7
6
  */
8
- var __importDefault = (this && this.__importDefault) || function (mod) {
9
- return (mod && mod.__esModule) ? mod : { "default": mod };
10
- };
11
- Object.defineProperty(exports, "__esModule", { value: true });
12
- exports.guarantees = exports.categories = exports.patterns = exports.version = exports.canon = void 0;
13
- exports.getPattern = getPattern;
14
- exports.getPatternsByCategory = getPatternsByCategory;
15
- exports.getEnforcedPatterns = getEnforcedPatterns;
16
- exports.getPatternsByRule = getPatternsByRule;
17
- exports.getGuarantee = getGuarantee;
18
- exports.getPatternsForGuarantee = getPatternsForGuarantee;
19
- exports.isValidPattern = isValidPattern;
20
- exports.getEnforcementStats = getEnforcementStats;
21
- const schema_json_1 = __importDefault(require("../schema.json"));
7
+ import schema from '../schema.json';
22
8
  // Export the full schema
23
- exports.canon = schema_json_1.default;
9
+ export const canon = schema;
24
10
  // Export version
25
- exports.version = schema_json_1.default.version;
11
+ export const version = schema.version;
26
12
  // Export patterns array
27
- exports.patterns = schema_json_1.default.patterns;
13
+ export const patterns = schema.patterns;
28
14
  // Export categories array
29
- exports.categories = schema_json_1.default.categories;
15
+ export const categories = schema.categories;
30
16
  // Export guarantees array
31
- exports.guarantees = schema_json_1.default.guarantees;
17
+ export const guarantees = schema.guarantees;
32
18
  /**
33
19
  * Get a pattern by ID
34
20
  * @param id - Pattern ID (e.g., "001", "002")
35
21
  * @returns Pattern object or undefined if not found
36
22
  */
37
- function getPattern(id) {
38
- return exports.patterns.find((p) => p.id === id);
23
+ export function getPattern(id) {
24
+ return patterns.find((p) => p.id === id);
39
25
  }
40
26
  /**
41
27
  * Get all patterns in a category
42
28
  * @param category - Category ID (e.g., "rendering", "typography")
43
29
  * @returns Array of patterns in that category
44
30
  */
45
- function getPatternsByCategory(category) {
46
- return exports.patterns.filter((p) => p.category === category);
31
+ export function getPatternsByCategory(category) {
32
+ return patterns.filter((p) => p.category === category);
47
33
  }
48
34
  /**
49
35
  * Get all patterns enforced by ESLint
50
36
  * @returns Array of ESLint-enforced patterns
51
37
  */
52
- function getEnforcedPatterns() {
53
- return exports.patterns.filter((p) => p.enforcement === 'eslint');
38
+ export function getEnforcedPatterns() {
39
+ return patterns.filter((p) => p.enforcement === 'eslint');
54
40
  }
55
41
  /**
56
42
  * Get all patterns with a specific ESLint rule
57
43
  * @param rule - ESLint rule name (e.g., "gallop/no-client-blocks")
58
44
  * @returns Array of patterns using that rule
59
45
  */
60
- function getPatternsByRule(rule) {
61
- return exports.patterns.filter((p) => p.rule === rule);
46
+ export function getPatternsByRule(rule) {
47
+ return patterns.filter((p) => p.rule === rule);
62
48
  }
63
49
  /**
64
50
  * Get a guarantee by ID
65
51
  * @param id - Guarantee ID (e.g., "SEO_STABLE")
66
52
  * @returns Guarantee object or undefined if not found
67
53
  */
68
- function getGuarantee(id) {
69
- return exports.guarantees.find((g) => g.id === id);
54
+ export function getGuarantee(id) {
55
+ return guarantees.find((g) => g.id === id);
70
56
  }
71
57
  /**
72
58
  * Get all patterns associated with a guarantee
73
59
  * @param guaranteeId - Guarantee ID (e.g., "SEO_STABLE")
74
60
  * @returns Array of patterns that support this guarantee
75
61
  */
76
- function getPatternsForGuarantee(guaranteeId) {
62
+ export function getPatternsForGuarantee(guaranteeId) {
77
63
  const guarantee = getGuarantee(guaranteeId);
78
64
  if (!guarantee)
79
65
  return [];
80
- return exports.patterns.filter((p) => guarantee.patterns.includes(p.id));
66
+ return patterns.filter((p) => guarantee.patterns.includes(p.id));
81
67
  }
82
68
  /**
83
69
  * Check if a pattern ID is valid
84
70
  * @param id - Pattern ID to check
85
71
  * @returns true if valid, false otherwise
86
72
  */
87
- function isValidPattern(id) {
88
- return exports.patterns.some((p) => p.id === id);
73
+ export function isValidPattern(id) {
74
+ return patterns.some((p) => p.id === id);
89
75
  }
90
76
  /**
91
77
  * Get pattern count by enforcement type
92
78
  * @returns Object with counts per enforcement type
93
79
  */
94
- function getEnforcementStats() {
80
+ export function getEnforcementStats() {
95
81
  const stats = {};
96
- for (const pattern of exports.patterns) {
82
+ for (const pattern of patterns) {
97
83
  stats[pattern.enforcement] = (stats[pattern.enforcement] || 0) + 1;
98
84
  }
99
85
  return stats;
100
86
  }
101
87
  // Default export
102
- exports.default = {
103
- version: exports.version,
104
- patterns: exports.patterns,
105
- categories: exports.categories,
106
- guarantees: exports.guarantees,
88
+ export default {
89
+ version,
90
+ patterns,
91
+ categories,
92
+ guarantees,
107
93
  getPattern,
108
94
  getPatternsByCategory,
109
95
  getEnforcedPatterns,
@@ -113,4 +99,4 @@ exports.default = {
113
99
  isValidPattern,
114
100
  getEnforcementStats,
115
101
  };
116
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";AAAA;;;;;GAKG;;;;;;AAoEH,gCAEC;AAOD,sDAEC;AAMD,kDAEC;AAOD,8CAEC;AAOD,oCAEC;AAOD,0DAIC;AAOD,wCAEC;AAMD,kDAMC;AAvID,iEAAmC;AA8CnC,yBAAyB;AACZ,QAAA,KAAK,GAAgB,qBAAqB,CAAA;AAEvD,iBAAiB;AACJ,QAAA,OAAO,GAAG,qBAAM,CAAC,OAAO,CAAA;AAErC,wBAAwB;AACX,QAAA,QAAQ,GAAc,qBAAM,CAAC,QAAqB,CAAA;AAE/D,0BAA0B;AACb,QAAA,UAAU,GAAe,qBAAM,CAAC,UAAU,CAAA;AAEvD,0BAA0B;AACb,QAAA,UAAU,GAAgB,qBAAM,CAAC,UAAyB,CAAA;AAEvE;;;;GAIG;AACH,SAAgB,UAAU,CAAC,EAAU;IACnC,OAAO,gBAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,CAAA;AAC1C,CAAC;AAED;;;;GAIG;AACH,SAAgB,qBAAqB,CAAC,QAAyB;IAC7D,OAAO,gBAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,QAAQ,CAAC,CAAA;AACxD,CAAC;AAED;;;GAGG;AACH,SAAgB,mBAAmB;IACjC,OAAO,gBAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,KAAK,QAAQ,CAAC,CAAA;AAC3D,CAAC;AAED;;;;GAIG;AACH,SAAgB,iBAAiB,CAAC,IAAY;IAC5C,OAAO,gBAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,CAAC,CAAA;AAChD,CAAC;AAED;;;;GAIG;AACH,SAAgB,YAAY,CAAC,EAAU;IACrC,OAAO,kBAAU,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,CAAA;AAC5C,CAAC;AAED;;;;GAIG;AACH,SAAgB,uBAAuB,CAAC,WAAmB;IACzD,MAAM,SAAS,GAAG,YAAY,CAAC,WAAW,CAAC,CAAA;IAC3C,IAAI,CAAC,SAAS;QAAE,OAAO,EAAE,CAAA;IACzB,OAAO,gBAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAA;AAClE,CAAC;AAED;;;;GAIG;AACH,SAAgB,cAAc,CAAC,EAAU;IACvC,OAAO,gBAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,CAAA;AAC1C,CAAC;AAED;;;GAGG;AACH,SAAgB,mBAAmB;IACjC,MAAM,KAAK,GAA2B,EAAE,CAAA;IACxC,KAAK,MAAM,OAAO,IAAI,gBAAQ,EAAE,CAAC;QAC/B,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAA;IACpE,CAAC;IACD,OAAO,KAAK,CAAA;AACd,CAAC;AAED,iBAAiB;AACjB,kBAAe;IACb,OAAO,EAAP,eAAO;IACP,QAAQ,EAAR,gBAAQ;IACR,UAAU,EAAV,kBAAU;IACV,UAAU,EAAV,kBAAU;IACV,UAAU;IACV,qBAAqB;IACrB,mBAAmB;IACnB,iBAAiB;IACjB,YAAY;IACZ,uBAAuB;IACvB,cAAc;IACd,mBAAmB;CACpB,CAAA","sourcesContent":["/**\n * @gallop/canon\n *\n * Gallop Enterprise Architecture Canon\n * Versioned, AI-compatible, auditable web architecture patterns\n */\n\nimport schema from '../schema.json'\n\n// Types\nexport interface Pattern {\n  id: string\n  title: string\n  file: string\n  category: PatternCategory\n  status: 'stable' | 'proposed' | 'deprecated'\n  enforcement: 'eslint' | 'documentation' | 'ci'\n  rule: string | null\n  summary: string\n}\n\nexport interface Category {\n  id: string\n  name: string\n  description: string\n}\n\nexport interface Guarantee {\n  id: string\n  name: string\n  since: string\n  status: 'stable' | 'proposed' | 'deprecated'\n  patterns: string[]\n}\n\nexport type PatternCategory =\n  | 'rendering'\n  | 'layout'\n  | 'typography'\n  | 'structure'\n  | 'styling'\n  | 'components'\n  | 'seo'\n\nexport interface CanonSchema {\n  name: string\n  version: string\n  description: string\n  categories: Category[]\n  patterns: Pattern[]\n  guarantees: Guarantee[]\n}\n\n// Export the full schema\nexport const canon: CanonSchema = schema as CanonSchema\n\n// Export version\nexport const version = schema.version\n\n// Export patterns array\nexport const patterns: Pattern[] = schema.patterns as Pattern[]\n\n// Export categories array\nexport const categories: Category[] = schema.categories\n\n// Export guarantees array\nexport const guarantees: Guarantee[] = schema.guarantees as Guarantee[]\n\n/**\n * Get a pattern by ID\n * @param id - Pattern ID (e.g., \"001\", \"002\")\n * @returns Pattern object or undefined if not found\n */\nexport function getPattern(id: string): Pattern | undefined {\n  return patterns.find((p) => p.id === id)\n}\n\n/**\n * Get all patterns in a category\n * @param category - Category ID (e.g., \"rendering\", \"typography\")\n * @returns Array of patterns in that category\n */\nexport function getPatternsByCategory(category: PatternCategory): Pattern[] {\n  return patterns.filter((p) => p.category === category)\n}\n\n/**\n * Get all patterns enforced by ESLint\n * @returns Array of ESLint-enforced patterns\n */\nexport function getEnforcedPatterns(): Pattern[] {\n  return patterns.filter((p) => p.enforcement === 'eslint')\n}\n\n/**\n * Get all patterns with a specific ESLint rule\n * @param rule - ESLint rule name (e.g., \"gallop/no-client-blocks\")\n * @returns Array of patterns using that rule\n */\nexport function getPatternsByRule(rule: string): Pattern[] {\n  return patterns.filter((p) => p.rule === rule)\n}\n\n/**\n * Get a guarantee by ID\n * @param id - Guarantee ID (e.g., \"SEO_STABLE\")\n * @returns Guarantee object or undefined if not found\n */\nexport function getGuarantee(id: string): Guarantee | undefined {\n  return guarantees.find((g) => g.id === id)\n}\n\n/**\n * Get all patterns associated with a guarantee\n * @param guaranteeId - Guarantee ID (e.g., \"SEO_STABLE\")\n * @returns Array of patterns that support this guarantee\n */\nexport function getPatternsForGuarantee(guaranteeId: string): Pattern[] {\n  const guarantee = getGuarantee(guaranteeId)\n  if (!guarantee) return []\n  return patterns.filter((p) => guarantee.patterns.includes(p.id))\n}\n\n/**\n * Check if a pattern ID is valid\n * @param id - Pattern ID to check\n * @returns true if valid, false otherwise\n */\nexport function isValidPattern(id: string): boolean {\n  return patterns.some((p) => p.id === id)\n}\n\n/**\n * Get pattern count by enforcement type\n * @returns Object with counts per enforcement type\n */\nexport function getEnforcementStats(): Record<string, number> {\n  const stats: Record<string, number> = {}\n  for (const pattern of patterns) {\n    stats[pattern.enforcement] = (stats[pattern.enforcement] || 0) + 1\n  }\n  return stats\n}\n\n// Default export\nexport default {\n  version,\n  patterns,\n  categories,\n  guarantees,\n  getPattern,\n  getPatternsByCategory,\n  getEnforcedPatterns,\n  getPatternsByRule,\n  getGuarantee,\n  getPatternsForGuarantee,\n  isValidPattern,\n  getEnforcementStats,\n}\n"]}
102
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,MAAM,MAAM,gBAAgB,CAAA;AA8CnC,yBAAyB;AACzB,MAAM,CAAC,MAAM,KAAK,GAAgB,MAAqB,CAAA;AAEvD,iBAAiB;AACjB,MAAM,CAAC,MAAM,OAAO,GAAG,MAAM,CAAC,OAAO,CAAA;AAErC,wBAAwB;AACxB,MAAM,CAAC,MAAM,QAAQ,GAAc,MAAM,CAAC,QAAqB,CAAA;AAE/D,0BAA0B;AAC1B,MAAM,CAAC,MAAM,UAAU,GAAe,MAAM,CAAC,UAAU,CAAA;AAEvD,0BAA0B;AAC1B,MAAM,CAAC,MAAM,UAAU,GAAgB,MAAM,CAAC,UAAyB,CAAA;AAEvE;;;;GAIG;AACH,MAAM,UAAU,UAAU,CAAC,EAAU;IACnC,OAAO,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,CAAA;AAC1C,CAAC;AAED;;;;GAIG;AACH,MAAM,UAAU,qBAAqB,CAAC,QAAyB;IAC7D,OAAO,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,QAAQ,CAAC,CAAA;AACxD,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,mBAAmB;IACjC,OAAO,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,KAAK,QAAQ,CAAC,CAAA;AAC3D,CAAC;AAED;;;;GAIG;AACH,MAAM,UAAU,iBAAiB,CAAC,IAAY;IAC5C,OAAO,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,CAAC,CAAA;AAChD,CAAC;AAED;;;;GAIG;AACH,MAAM,UAAU,YAAY,CAAC,EAAU;IACrC,OAAO,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,CAAA;AAC5C,CAAC;AAED;;;;GAIG;AACH,MAAM,UAAU,uBAAuB,CAAC,WAAmB;IACzD,MAAM,SAAS,GAAG,YAAY,CAAC,WAAW,CAAC,CAAA;IAC3C,IAAI,CAAC,SAAS;QAAE,OAAO,EAAE,CAAA;IACzB,OAAO,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAA;AAClE,CAAC;AAED;;;;GAIG;AACH,MAAM,UAAU,cAAc,CAAC,EAAU;IACvC,OAAO,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,CAAA;AAC1C,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,mBAAmB;IACjC,MAAM,KAAK,GAA2B,EAAE,CAAA;IACxC,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE,CAAC;QAC/B,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAA;IACpE,CAAC;IACD,OAAO,KAAK,CAAA;AACd,CAAC;AAED,iBAAiB;AACjB,eAAe;IACb,OAAO;IACP,QAAQ;IACR,UAAU;IACV,UAAU;IACV,UAAU;IACV,qBAAqB;IACrB,mBAAmB;IACnB,iBAAiB;IACjB,YAAY;IACZ,uBAAuB;IACvB,cAAc;IACd,mBAAmB;CACpB,CAAA","sourcesContent":["/**\n * @gallop/canon\n *\n * Gallop Enterprise Architecture Canon\n * Versioned, AI-compatible, auditable web architecture patterns\n */\n\nimport schema from '../schema.json'\n\n// Types\nexport interface Pattern {\n  id: string\n  title: string\n  file: string\n  category: PatternCategory\n  status: 'stable' | 'proposed' | 'deprecated'\n  enforcement: 'eslint' | 'documentation' | 'ci'\n  rule: string | null\n  summary: string\n}\n\nexport interface Category {\n  id: string\n  name: string\n  description: string\n}\n\nexport interface Guarantee {\n  id: string\n  name: string\n  since: string\n  status: 'stable' | 'proposed' | 'deprecated'\n  patterns: string[]\n}\n\nexport type PatternCategory =\n  | 'rendering'\n  | 'layout'\n  | 'typography'\n  | 'structure'\n  | 'styling'\n  | 'components'\n  | 'seo'\n\nexport interface CanonSchema {\n  name: string\n  version: string\n  description: string\n  categories: Category[]\n  patterns: Pattern[]\n  guarantees: Guarantee[]\n}\n\n// Export the full schema\nexport const canon: CanonSchema = schema as CanonSchema\n\n// Export version\nexport const version = schema.version\n\n// Export patterns array\nexport const patterns: Pattern[] = schema.patterns as Pattern[]\n\n// Export categories array\nexport const categories: Category[] = schema.categories\n\n// Export guarantees array\nexport const guarantees: Guarantee[] = schema.guarantees as Guarantee[]\n\n/**\n * Get a pattern by ID\n * @param id - Pattern ID (e.g., \"001\", \"002\")\n * @returns Pattern object or undefined if not found\n */\nexport function getPattern(id: string): Pattern | undefined {\n  return patterns.find((p) => p.id === id)\n}\n\n/**\n * Get all patterns in a category\n * @param category - Category ID (e.g., \"rendering\", \"typography\")\n * @returns Array of patterns in that category\n */\nexport function getPatternsByCategory(category: PatternCategory): Pattern[] {\n  return patterns.filter((p) => p.category === category)\n}\n\n/**\n * Get all patterns enforced by ESLint\n * @returns Array of ESLint-enforced patterns\n */\nexport function getEnforcedPatterns(): Pattern[] {\n  return patterns.filter((p) => p.enforcement === 'eslint')\n}\n\n/**\n * Get all patterns with a specific ESLint rule\n * @param rule - ESLint rule name (e.g., \"gallop/no-client-blocks\")\n * @returns Array of patterns using that rule\n */\nexport function getPatternsByRule(rule: string): Pattern[] {\n  return patterns.filter((p) => p.rule === rule)\n}\n\n/**\n * Get a guarantee by ID\n * @param id - Guarantee ID (e.g., \"SEO_STABLE\")\n * @returns Guarantee object or undefined if not found\n */\nexport function getGuarantee(id: string): Guarantee | undefined {\n  return guarantees.find((g) => g.id === id)\n}\n\n/**\n * Get all patterns associated with a guarantee\n * @param guaranteeId - Guarantee ID (e.g., \"SEO_STABLE\")\n * @returns Array of patterns that support this guarantee\n */\nexport function getPatternsForGuarantee(guaranteeId: string): Pattern[] {\n  const guarantee = getGuarantee(guaranteeId)\n  if (!guarantee) return []\n  return patterns.filter((p) => guarantee.patterns.includes(p.id))\n}\n\n/**\n * Check if a pattern ID is valid\n * @param id - Pattern ID to check\n * @returns true if valid, false otherwise\n */\nexport function isValidPattern(id: string): boolean {\n  return patterns.some((p) => p.id === id)\n}\n\n/**\n * Get pattern count by enforcement type\n * @returns Object with counts per enforcement type\n */\nexport function getEnforcementStats(): Record<string, number> {\n  const stats: Record<string, number> = {}\n  for (const pattern of patterns) {\n    stats[pattern.enforcement] = (stats[pattern.enforcement] || 0) + 1\n  }\n  return stats\n}\n\n// Default export\nexport default {\n  version,\n  patterns,\n  categories,\n  guarantees,\n  getPattern,\n  getPatternsByCategory,\n  getEnforcedPatterns,\n  getPatternsByRule,\n  getGuarantee,\n  getPatternsForGuarantee,\n  isValidPattern,\n  getEnforcementStats,\n}\n"]}
package/package.json CHANGED
@@ -1,9 +1,23 @@
1
1
  {
2
2
  "name": "@gallop.software/canon",
3
- "version": "1.0.0",
4
- "description": "Gallop Enterprise Architecture Canon - Versioned, AI-compatible, auditable web architecture patterns",
3
+ "version": "2.0.0",
4
+ "type": "module",
5
+ "description": "Gallop Canon - Architecture patterns, ESLint plugin, and CLI for template governance",
5
6
  "main": "dist/index.js",
6
7
  "types": "dist/index.d.ts",
8
+ "exports": {
9
+ ".": {
10
+ "types": "./dist/index.d.ts",
11
+ "import": "./dist/index.js"
12
+ },
13
+ "./eslint": {
14
+ "types": "./dist/eslint/index.d.ts",
15
+ "import": "./dist/eslint/index.js"
16
+ }
17
+ },
18
+ "bin": {
19
+ "gallop": "./dist/cli/index.js"
20
+ },
7
21
  "files": [
8
22
  "dist",
9
23
  "patterns",
@@ -20,10 +34,13 @@
20
34
  "architecture",
21
35
  "patterns",
22
36
  "canon",
37
+ "eslint",
38
+ "eslintplugin",
23
39
  "nextjs",
24
40
  "react",
25
41
  "governance",
26
- "ai-compatible"
42
+ "ai-compatible",
43
+ "cli"
27
44
  ],
28
45
  "author": {
29
46
  "name": "Gallop",
@@ -35,7 +52,20 @@
35
52
  "url": "https://github.com/gallop-software/gallop",
36
53
  "directory": "canon"
37
54
  },
55
+ "peerDependencies": {
56
+ "eslint": ">=8.0.0"
57
+ },
58
+ "peerDependenciesMeta": {
59
+ "eslint": {
60
+ "optional": true
61
+ }
62
+ },
63
+ "dependencies": {
64
+ "@typescript-eslint/utils": "^8.0.0"
65
+ },
38
66
  "devDependencies": {
67
+ "@types/eslint": "^9.6.0",
68
+ "@types/node": "^20.0.0",
39
69
  "typescript": "^5.0.0"
40
70
  }
41
71
  }