npm-dropdown-package 1.0.0 → 1.0.2

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 ADDED
Binary file
package/build/index.js CHANGED
@@ -1,6 +1,6 @@
1
1
  class GenerateDropdownData {
2
2
  constructor(featureLayers, fieldNames) {
3
- // Define method
3
+ // Define 'Method'
4
4
  this.dropDownQuery = async () => {
5
5
  // ################### One Feature Layer ################### //
6
6
  if (this.featureLayers.length === 1) {
@@ -95,13 +95,14 @@ class GenerateDropdownData {
95
95
  else {
96
96
  // 1. Pairs for 1st feature layer
97
97
  var query13 = this.featureLayers[0].createQuery();
98
+ query13.outFields = ["*"];
98
99
  query13.outFields = [this.fieldNames[0], this.fieldNames[1]];
99
100
  query13.orderByFields = [this.fieldNames[0], this.fieldNames[1]];
100
101
  query13.groupByFieldsForStatistics = [
101
102
  this.fieldNames[0],
102
103
  this.fieldNames[1],
103
104
  ];
104
- query13.where = `${this.fieldNames[0]} IS NOT NULL`;
105
+ // query13.where = `${this.fieldNames[0]} IS NOT NULL`;
105
106
  const pairQ = this.featureLayers[0]
106
107
  .queryFeatures(query13)
107
108
  .then((response) => {
@@ -129,20 +130,20 @@ class GenerateDropdownData {
129
130
  .map((item) => item.field1)
130
131
  .filter((field1, index, emp) => emp.indexOf(field1) === index);
131
132
  // 3. Compile for all the fields:
132
- const field1Array = uniqueField1.map((field1, index) => {
133
+ const field1Array = uniqueField1.map((field1) => {
133
134
  const filterField1 = pairs.filter((emp) => emp.field1 === field1);
134
135
  const uniqueField2 = filterField1
135
136
  .map((item) => item.field2)
136
137
  .filter((field2, index, emp) => emp.indexOf(field2) === index);
137
138
  // 3.2. Unique values for field3 corresponding to field1 and field2
138
139
  // eslint-disable-next-line array-callback-return
139
- const field2Array = uniqueField2.map((field2, index) => {
140
+ const field2Array = uniqueField2.map((field2) => {
140
141
  const filterField2 = pairs.filter((emp) => emp.field1 === field1 && emp.field2 === field2);
141
142
  const uniqueField3 = filterField2
142
143
  .map((item) => item.field3)
143
144
  .filter((field3, index, emp) => emp.indexOf(field3) === index);
144
145
  // eslint-disable-next-line array-callback-return
145
- const field3Array = uniqueField3.map((field3, index) => {
146
+ const field3Array = uniqueField3.map((field3) => {
146
147
  return Object.assign({
147
148
  name: field3, // field3 = typeName (name?)
148
149
  });
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "npm-dropdown-package",
3
- "version": "1.0.0",
3
+ "version": "1.0.2",
4
4
  "description": "A package to create an object-array using feature layers hosted in Portal for ArcGIS for react-select dropdown",
5
5
  "main": "build/index.js",
6
6
  "types": "build/index.d.ts",
@@ -25,7 +25,6 @@
25
25
  "devDependencies": {
26
26
  "typescript": "^5.9.3"
27
27
  },
28
-
29
28
  "peerDependencies": {
30
29
  "@arcgis/core": "^4.34.6"
31
30
  }
package/src/index.ts CHANGED
@@ -9,7 +9,7 @@ class GenerateDropdownData {
9
9
  this.fieldNames = fieldNames;
10
10
  }
11
11
 
12
- // Define method
12
+ // Define 'Method'
13
13
  dropDownQuery = async () => {
14
14
  // ################### One Feature Layer ################### //
15
15
  if (this.featureLayers.length === 1) {
@@ -135,13 +135,14 @@ class GenerateDropdownData {
135
135
  } else {
136
136
  // 1. Pairs for 1st feature layer
137
137
  var query13 = this.featureLayers[0].createQuery();
138
+ query13.outFields = ["*"];
138
139
  query13.outFields = [this.fieldNames[0], this.fieldNames[1]];
139
140
  query13.orderByFields = [this.fieldNames[0], this.fieldNames[1]];
140
141
  query13.groupByFieldsForStatistics = [
141
142
  this.fieldNames[0],
142
143
  this.fieldNames[1],
143
144
  ];
144
- query13.where = `${this.fieldNames[0]} IS NOT NULL`;
145
+ // query13.where = `${this.fieldNames[0]} IS NOT NULL`;
145
146
 
146
147
  const pairQ: any = this.featureLayers[0]
147
148
  .queryFeatures(query13)
@@ -182,7 +183,7 @@ class GenerateDropdownData {
182
183
  );
183
184
 
184
185
  // 3. Compile for all the fields:
185
- const field1Array = uniqueField1.map((field1: any, index: number) => {
186
+ const field1Array = uniqueField1.map((field1: any) => {
186
187
  const filterField1 = pairs.filter(
187
188
  (emp: any) => emp.field1 === field1
188
189
  );
@@ -195,7 +196,7 @@ class GenerateDropdownData {
195
196
 
196
197
  // 3.2. Unique values for field3 corresponding to field1 and field2
197
198
  // eslint-disable-next-line array-callback-return
198
- const field2Array = uniqueField2.map((field2: any, index: any) => {
199
+ const field2Array = uniqueField2.map((field2: any) => {
199
200
  const filterField2 = pairs.filter(
200
201
  (emp: any) => emp.field1 === field1 && emp.field2 === field2
201
202
  );
@@ -208,7 +209,7 @@ class GenerateDropdownData {
208
209
  );
209
210
 
210
211
  // eslint-disable-next-line array-callback-return
211
- const field3Array = uniqueField3.map((field3: any, index: any) => {
212
+ const field3Array = uniqueField3.map((field3: any) => {
212
213
  return Object.assign({
213
214
  name: field3, // field3 = typeName (name?)
214
215
  });