@airfleet/generator-init 0.21.3 → 0.22.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.
@@ -5,7 +5,7 @@
5
5
  "body": [
6
6
  "<?php",
7
7
  "",
8
- "namespace Airfleet\\Plugins\\<%= nameNoAirfleet.pascal %>\\Features;",
8
+ "namespace Airfleet\\Plugins\\<%= nameNoAirfleet.pascal %>\\\\${TM_DIRECTORY/^.+[\\/\\\\]+(.*)$/$1/};",
9
9
  "",
10
10
  "use Airfleet\\Plugins\\<%= nameNoAirfleet.pascal %>\\Vendor\\Airfleet\\Framework\\Features\\BasePluginFeature;",
11
11
  "",
@@ -41,7 +41,7 @@
41
41
  "body": [
42
42
  "<?php",
43
43
  "",
44
- "namespace Airfleet\\Plugins\\<%= nameNoAirfleet.pascal %>\\Views\\\\${1|Components,Blocks,Partials,Templates,CustomTemplates|}\\\\${TM_FILENAME_BASE/(.+)Controller/$1/};",
44
+ "namespace Airfleet\\Plugins\\<%= nameNoAirfleet.pascal %>\\Views\\\\${1|Components,Blocks,Partials,Templates,CustomTemplates|}\\\\${TM_FILENAME_BASE/(.+)Setup/$1/};",
45
45
  "",
46
46
  "use Airfleet\\Plugins\\Views\\View\\ViewSetup;",
47
47
  "",
@@ -58,7 +58,7 @@
58
58
  "scope": "javascript",
59
59
  "prefix": "afjs",
60
60
  "body": [
61
- "export class ${TM_FILENAME_BASE/(.)([^-]*)-?/${1:/upcase}${2}/g} {",
61
+ "export class ${TM_FILENAME_BASE/([^.]*)(\\..+)*$/${1:/pascalcase}/} {",
62
62
  " initialize() {",
63
63
  " const { domReady } = window._airfleet.elements.core;",
64
64
  "",
@@ -68,7 +68,7 @@
68
68
  " }",
69
69
  "}",
70
70
  "",
71
- "new ${TM_FILENAME_BASE/(.)([^-]*)-?/${1:/upcase}${2}/g}().initialize();",
71
+ "new ${TM_FILENAME_BASE/([^.]*)(\\..+)*$/${1:/pascalcase}/}().initialize();",
72
72
  ""
73
73
  ],
74
74
  "description": "Create a view script"
@@ -90,10 +90,10 @@
90
90
  "body": [
91
91
  "{",
92
92
  " \"$schema\": \"https://advancedcustomfields.com/schemas/json/main/block.json\",",
93
- " \"name\": \"${1|airfleet/,airfleet/elements-|}$TM_FILENAME_BASE\",",
94
- " \"title\": \"$2${TM_FILENAME_BASE/-/ /g}\",",
93
+ " \"name\": \"${1|airfleet/,airfleet/elements-|}${TM_FILENAME_BASE/([^.]*)(\\..+)*$/$1/}\",",
94
+ " \"title\": \"$2${TM_FILENAME_BASE/([^\\.]*)(\\.block)?$/${1:/capitalize}/}\",",
95
95
  " \"description\": \"$3\",",
96
- " \"keywords\": [\"airfleet\", \"${TM_FILENAME_BASE/-/\", \"/g}\"$4]",
96
+ " \"keywords\": [\"airfleet\", \"${TM_FILENAME_BASE/([^.]*)(\\..+)*$/$1/}\"$4]",
97
97
  "}",
98
98
  ""
99
99
  ],
@@ -166,6 +166,6 @@
166
166
  "</div>",
167
167
  ""
168
168
  ],
169
- "description": "Airfleet Partial Template (Blade)"
169
+ "description": "Bootstrap a Blade template for a partial"
170
170
  }
171
171
  }
@@ -5,7 +5,7 @@
5
5
  "body": [
6
6
  "<?php",
7
7
  "",
8
- "namespace Airfleet\\Plugins\\<%= nameNoAirfleet.pascal %>\\Features;",
8
+ "namespace Airfleet\\Plugins\\<%= nameNoAirfleet.pascal %>\\\\${TM_DIRECTORY/^.+[\\/\\\\]+(.*)$/$1/};",
9
9
  "",
10
10
  "use Airfleet\\Plugins\\<%= nameNoAirfleet.pascal %>\\Vendor\\Airfleet\\Framework\\Features\\BasePluginFeature;",
11
11
  "",
@@ -41,7 +41,7 @@
41
41
  "body": [
42
42
  "<?php",
43
43
  "",
44
- "namespace Airfleet\\Plugins\\<%= nameNoAirfleet.pascal %>\\Views\\\\${1|Components,Blocks,Partials,Templates,CustomTemplates|}\\\\${TM_FILENAME_BASE/(.+)Controller/$1/};",
44
+ "namespace Airfleet\\Plugins\\<%= nameNoAirfleet.pascal %>\\Views\\\\${1|Components,Blocks,Partials,Templates,CustomTemplates|}\\\\${TM_FILENAME_BASE/(.+)Setup/$1/};",
45
45
  "",
46
46
  "use Airfleet\\Plugins\\Views\\View\\ViewSetup;",
47
47
  "",
@@ -58,7 +58,7 @@
58
58
  "scope": "javascript",
59
59
  "prefix": "afjs",
60
60
  "body": [
61
- "export class ${TM_FILENAME_BASE/(.)([^-]*)-?/${1:/upcase}${2}/g} {",
61
+ "export class ${TM_FILENAME_BASE/([^.]*)(\\..+)*$/${1:/pascalcase}/} {",
62
62
  " initialize() {",
63
63
  " const { domReady } = window._airfleet.elements.core;",
64
64
  "",
@@ -68,7 +68,7 @@
68
68
  " }",
69
69
  "}",
70
70
  "",
71
- "new ${TM_FILENAME_BASE/(.)([^-]*)-?/${1:/upcase}${2}/g}().initialize();",
71
+ "new ${TM_FILENAME_BASE/([^.]*)(\\..+)*$/${1:/pascalcase}/}().initialize();",
72
72
  ""
73
73
  ],
74
74
  "description": "Create a view script"
@@ -90,10 +90,10 @@
90
90
  "body": [
91
91
  "{",
92
92
  " \"$schema\": \"https://advancedcustomfields.com/schemas/json/main/block.json\",",
93
- " \"name\": \"${1|airfleet/,airfleet/elements-|}$TM_FILENAME_BASE\",",
94
- " \"title\": \"$2${TM_FILENAME_BASE/-/ /g}\",",
93
+ " \"name\": \"${1|airfleet/,airfleet/elements-|}${TM_FILENAME_BASE/([^.]*)(\\..+)*$/$1/}\",",
94
+ " \"title\": \"$2${TM_FILENAME_BASE/([^\\.]*)(\\.block)?$/${1:/capitalize}/}\",",
95
95
  " \"description\": \"$3\",",
96
- " \"keywords\": [\"airfleet\", \"${TM_FILENAME_BASE/-/\", \"/g}\"$4]",
96
+ " \"keywords\": [\"airfleet\", \"${TM_FILENAME_BASE/([^.]*)(\\..+)*$/$1/}\"$4]",
97
97
  "}",
98
98
  ""
99
99
  ],
@@ -40,7 +40,7 @@ export default class extends Generator {
40
40
  ? [this.viewsPrefix, this.viewType.slug, this.name.slug]
41
41
  : [this.viewType.slug, this.name.slug]
42
42
  ).join("-");
43
- this.viewFolder = `${this.answers.viewsFolder}/${this.viewType.slug}/${this.name.slug}`;
43
+ this.viewFolder = this._viewFolder();
44
44
  this.cssClassPrefix = this._cssClassPrefix(this.viewType.slug);
45
45
  this.cssClass = `${this.cssClassPrefix}-${this.name.slug}`;
46
46
  this.namespace = this._phpNamespace();
@@ -64,7 +64,30 @@ export default class extends Generator {
64
64
  };
65
65
  }
66
66
 
67
+ _viewFolder() {
68
+ return `${this._viewFolderBase()}/${this.viewType.slug}/${this.name.slug}`;
69
+ }
70
+
71
+ _viewFolderBase() {
72
+ if (this.answers.source === "lightyear-theme") {
73
+ return this.answers.viewsFolderTheme;
74
+ }
75
+
76
+ return this.answers.viewsFolder;
77
+ }
78
+
67
79
  _viewsPrefix() {
80
+ if (this.answers.source === "lightyear-theme") {
81
+ switch (this.answers.viewsFolderTheme) {
82
+ case "views":
83
+ return "";
84
+ case "views-elements":
85
+ return "elements";
86
+ default:
87
+ throw new Error("Unable to determine views prefix. Unexpected views folder: " + this.answers.viewsFolderTheme);
88
+ }
89
+ }
90
+
68
91
  if (this.answers.viewsPrefix === "other") {
69
92
  return nameCases(this.answers.viewsPrefixOther).slug;
70
93
  }
@@ -77,6 +100,10 @@ export default class extends Generator {
77
100
  }
78
101
 
79
102
  _phpNamespace() {
103
+ return this._phpBaseNamespace() + "\\" + this._phpViewsNamespace();
104
+ }
105
+
106
+ _phpBaseNamespace() {
80
107
  switch (this.answers.source) {
81
108
  case "starter-theme":
82
109
  return "App";
@@ -87,6 +114,14 @@ export default class extends Generator {
87
114
  }
88
115
  }
89
116
 
117
+ _phpViewsNamespace() {
118
+ if (this.answers.source === "lightyear-theme") {
119
+ return nameCases(this.answers.viewsFolderTheme).pascal;
120
+ }
121
+
122
+ return this.answers.viewsNamespace;
123
+ }
124
+
90
125
  _cssClassPrefix(viewType) {
91
126
  switch (viewType) {
92
127
  case "partials":
@@ -15,14 +15,21 @@ export default class {
15
15
  if (this.answers.source === "plugin") {
16
16
  await this._promptNext([this._pluginNamePrompt()]);
17
17
  }
18
- await this._promptNext([
19
- this._viewsFolderPrompt(),
20
- this._viewsPrefixPrompt(),
21
- ]);
22
18
 
23
- if (this.answers.viewsPrefix === "other") {
24
- await this._promptNext([this._viewsPrefixOtherPrompt()]);
19
+ if (this.answers.source === "lightyear-theme") {
20
+ await this._promptNext([this._themeViewsFolderPrompt()]);
21
+ } else {
22
+ await this._promptNext([
23
+ this._viewsFolderPrompt(),
24
+ this._viewsNamespacePrompt(),
25
+ this._viewsPrefixPrompt(),
26
+ ]);
27
+
28
+ if (this.answers.viewsPrefix === "other") {
29
+ await this._promptNext([this._viewsPrefixOtherPrompt()]);
30
+ }
25
31
  }
32
+
26
33
  await this._promptNext([
27
34
  this._viewTypePrompt(),
28
35
  this._viewNamePrompt(),
@@ -78,7 +85,7 @@ export default class {
78
85
  value: "plugin",
79
86
  },
80
87
  ],
81
- default: "starter-theme",
88
+ default: "lightyear-theme",
82
89
  store: true,
83
90
  };
84
91
  }
@@ -93,6 +100,45 @@ export default class {
93
100
  };
94
101
  }
95
102
 
103
+ _themeViewsFolderPrompt() {
104
+ return {
105
+ type: "list",
106
+ name: "viewsFolderTheme",
107
+ message: `Views folder?`,
108
+ choices: [
109
+ "views",
110
+ "views-elements",
111
+ ],
112
+ default: "views",
113
+ store: true,
114
+ };
115
+ }
116
+
117
+ _viewsFolderPrompt() {
118
+ return {
119
+ type: "input",
120
+ name: "viewsFolder",
121
+ message: "Views folder?",
122
+ validate: requiredText("Please enter the views folder"),
123
+ default: "views",
124
+ store: true,
125
+ };
126
+ }
127
+
128
+ _viewsNamespacePrompt() {
129
+ return {
130
+ type: "list",
131
+ name: "viewsNamespace",
132
+ message: `Views PHP namespace?`,
133
+ choices: [
134
+ "Views",
135
+ "ViewsElements",
136
+ ],
137
+ default: "Views",
138
+ store: true,
139
+ };
140
+ }
141
+
96
142
  _viewsPrefixPrompt() {
97
143
  return {
98
144
  type: "list",
@@ -117,17 +163,6 @@ export default class {
117
163
  };
118
164
  }
119
165
 
120
- _viewsFolderPrompt() {
121
- return {
122
- type: "input",
123
- name: "viewsFolder",
124
- message: "Views folder?",
125
- validate: requiredText("Please enter the views folder"),
126
- default: "views",
127
- store: true,
128
- };
129
- }
130
-
131
166
  _viewTypePrompt() {
132
167
  return {
133
168
  type: "list",
@@ -1,6 +1,6 @@
1
1
  <?php
2
2
 
3
- namespace <%= namespace %>\Views\<%= viewType.pascal %>\<%= name.pascal %>;
3
+ namespace <%= namespace %>\<%= viewType.pascal %>\<%= name.pascal %>;
4
4
 
5
5
  use Airfleet\Plugins\Views\View\ViewController;
6
6
 
@@ -1,6 +1,6 @@
1
1
  <?php
2
2
 
3
- namespace <%= namespace %>\Views\<%= viewType.pascal %>\<%= name.pascal %>;
3
+ namespace <%= namespace %>\<%= viewType.pascal %>\<%= name.pascal %>;
4
4
 
5
5
  use Airfleet\Plugins\Views\View\ViewSetup;
6
6
 
@@ -1,6 +1,6 @@
1
1
  <?php
2
2
 
3
- namespace <%= namespace %>\Views\<%= viewType.pascal %>\<%= name.pascal %>;
3
+ namespace <%= namespace %>\<%= viewType.pascal %>\<%= name.pascal %>;
4
4
 
5
5
  use Airfleet\Plugins\Views\View\ViewSetup;
6
6
 
@@ -0,0 +1,5 @@
1
+ @import '../../../assets/shared/styles/lib';
2
+
3
+ .<%= cssClass %> {
4
+ // TODO
5
+ }
@@ -68,26 +68,27 @@ export default class {
68
68
  }
69
69
 
70
70
  _stylesTemplates() {
71
+ const template = this.generator.answers.source === "lightyear-theme" ? `view-lightyear.scss.ejs` : `view.scss.ejs`;
71
72
  const extension = this.generator.answers.source === "starter-theme" ? "scss" : "entry.scss";
72
73
 
73
74
  return [
74
75
  {
75
- template: `view.scss.ejs`,
76
+ template,
76
77
  destination: `${this.generator.viewFolder}/${this.generator.name.slug}.${extension}`,
77
78
  isEnabled: this._styleEnabled("frontend"),
78
79
  },
79
80
  {
80
- template: `view.scss.ejs`,
81
+ template,
81
82
  destination: `${this.generator.viewFolder}/${this.generator.name.slug}.critical.${extension}`,
82
83
  isEnabled: this._styleEnabled("critical"),
83
84
  },
84
85
  {
85
- template: `view.scss.ejs`,
86
+ template,
86
87
  destination: `${this.generator.viewFolder}/${this.generator.name.slug}.editor.${extension}`,
87
88
  isEnabled: this._styleEnabled("editor"),
88
89
  },
89
90
  {
90
- template: `view.scss.ejs`,
91
+ template,
91
92
  destination: `${this.generator.viewFolder}/${this.generator.name.slug}.admin.${extension}`,
92
93
  isEnabled: this._styleEnabled("admin"),
93
94
  },
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@airfleet/generator-init",
3
3
  "description": "A Yeoman generator to scaffold common Airfleet features",
4
- "version": "0.21.3",
4
+ "version": "0.22.0",
5
5
  "scripts": {},
6
6
  "publishConfig": {
7
7
  "access": "public"