@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/cli/commands/audit.d.ts +7 -0
- package/dist/cli/commands/audit.js +172 -0
- package/dist/cli/commands/generate.d.ts +6 -0
- package/dist/cli/commands/generate.js +170 -0
- package/dist/cli/index.d.ts +2 -0
- package/dist/cli/index.js +104 -0
- package/dist/eslint/configs/recommended.d.ts +13 -0
- package/dist/eslint/configs/recommended.js +15 -0
- package/dist/eslint/configs/speedwell.d.ts +13 -0
- package/dist/eslint/configs/speedwell.js +17 -0
- package/dist/eslint/index.d.ts +37 -0
- package/dist/eslint/index.js +24 -0
- package/dist/eslint/rules/no-client-blocks.d.ts +5 -0
- package/dist/eslint/rules/no-client-blocks.js +45 -0
- package/dist/eslint/rules/no-container-in-section.d.ts +5 -0
- package/dist/eslint/rules/no-container-in-section.js +50 -0
- package/dist/eslint/rules/prefer-component-props.d.ts +5 -0
- package/dist/eslint/rules/prefer-component-props.js +100 -0
- package/dist/eslint/rules/prefer-typography-components.d.ts +3 -0
- package/dist/eslint/rules/prefer-typography-components.js +76 -0
- package/dist/eslint/utils/canon.d.ts +25 -0
- package/dist/eslint/utils/canon.js +50 -0
- package/dist/index.js +28 -42
- package/package.json +33 -3
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
|
-
|
|
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
|
-
|
|
9
|
+
export const canon = schema;
|
|
24
10
|
// Export version
|
|
25
|
-
|
|
11
|
+
export const version = schema.version;
|
|
26
12
|
// Export patterns array
|
|
27
|
-
|
|
13
|
+
export const patterns = schema.patterns;
|
|
28
14
|
// Export categories array
|
|
29
|
-
|
|
15
|
+
export const categories = schema.categories;
|
|
30
16
|
// Export guarantees array
|
|
31
|
-
|
|
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
|
|
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
|
|
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
|
|
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
|
|
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
|
|
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
|
|
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
|
|
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
|
|
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
|
-
|
|
103
|
-
version
|
|
104
|
-
patterns
|
|
105
|
-
categories
|
|
106
|
-
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,
|
|
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": "
|
|
4
|
-
"
|
|
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
|
}
|