form-payload 1.1.0 → 1.2.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/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "form-payload",
3
- "version": "1.1.0",
3
+ "version": "1.2.0",
4
4
  "description": "Gets form-payload via form.elements",
5
5
  "keywords": [
6
6
  "form",
@@ -1,11 +1,12 @@
1
1
  export type HTMLFormControlElement = import('../../libs/types/types.js').HTMLFormControlElement;
2
2
  export type HTMLFormOperationalControlElement = import('../../libs/types/types.js').HTMLFormOperationalControlElement;
3
3
  /**
4
+ * @template {unknown} T
4
5
  * @param {HTMLFormOperationalControlElement} controlNode
5
- * @returns {unknown}
6
+ * @returns {T}
6
7
  * @throws {FormPayloadError}
7
8
  */
8
- export function getFormControlPayload(controlNode: HTMLFormOperationalControlElement): unknown;
9
+ export function getFormControlPayload<T extends unknown>(controlNode: HTMLFormOperationalControlElement): T;
9
10
  /** @typedef {import('../../libs/types/types.js').HTMLFormControlElement} HTMLFormControlElement */
10
11
  /** @typedef {import('../../libs/types/types.js').HTMLFormOperationalControlElement} HTMLFormOperationalControlElement */
11
12
  /**
@@ -1 +1 @@
1
- {"version":3,"file":"get-form-control-payload.d.ts","sourceRoot":"","sources":["../../../../src/packages/get-form-control-payload/get-form-control-payload.js"],"names":[],"mappings":"qCAcc,OAAO,2BAA2B,EAAE,sBAAsB;gDAC1D,OAAO,2BAA2B,EAAE,iCAAiC;AA+BnF;;;;GAIG;AACH,mDAJW,iCAAiC,GAC/B,OAAO,CA0EnB;AA5GD,mGAAmG;AACnG,yHAAyH;AAEzH;;;;GAIG;AACH,8FAHc,sBAAsB,OAyBnC"}
1
+ {"version":3,"file":"get-form-control-payload.d.ts","sourceRoot":"","sources":["../../../../src/packages/get-form-control-payload/get-form-control-payload.js"],"names":[],"mappings":"qCAcc,OAAO,2BAA2B,EAAE,sBAAsB;gDAC1D,OAAO,2BAA2B,EAAE,iCAAiC;AA+BnF;;;;;GAKG;AACH,sEAJW,iCAAiC,KAqF3C;AAvHD,mGAAmG;AACnG,yHAAyH;AAEzH;;;;GAIG;AACH,8FAHc,sBAAsB,OAyBnC"}
@@ -45,8 +45,9 @@ const getFormControlsPayload = (...controlElements) => {
45
45
  };
46
46
 
47
47
  /**
48
+ * @template {unknown} T
48
49
  * @param {HTMLFormOperationalControlElement} controlNode
49
- * @returns {unknown}
50
+ * @returns {T}
50
51
  * @throws {FormPayloadError}
51
52
  */
52
53
  const getFormControlPayload = (controlNode) => {
@@ -63,47 +64,55 @@ const getFormControlPayload = (controlNode) => {
63
64
  case ControlType.TEXTAREA:
64
65
  case ControlType.SELECT_ONE:
65
66
  case ControlType.OUTPUT: {
66
- return getFormControlValue(
67
- /**
68
- * @type {HTMLInputElement
69
- * | HTMLOutputElement
70
- * | HTMLTextAreaElement
71
- * | HTMLSelectElement}
72
- */ (controlNode),
67
+ return /** @type {T} */ (
68
+ getFormControlValue(
69
+ /**
70
+ * @type {HTMLInputElement
71
+ * | HTMLOutputElement
72
+ * | HTMLTextAreaElement
73
+ * | HTMLSelectElement}
74
+ */ (controlNode),
75
+ )
73
76
  );
74
77
  }
75
78
  case ControlType.NUMBER:
76
79
  case ControlType.RANGE: {
77
- return getInputNumericValue(
78
- /** @type {HTMLInputElement} */ (controlNode),
80
+ return /** @type {T} */ (
81
+ getInputNumericValue(
82
+ /** @type {HTMLInputElement} */ (controlNode),
83
+ )
79
84
  );
80
85
  }
81
86
  case ControlType.CHECKBOX: {
82
- return getCheckboxValue(
83
- /** @type {HTMLInputElement} */ (controlNode),
87
+ return /** @type {T} */ (
88
+ getCheckboxValue(/** @type {HTMLInputElement} */ (controlNode))
84
89
  );
85
90
  }
86
91
  case ControlType.DATE:
87
92
  case ControlType.TIME:
88
93
  case ControlType.MONTH:
89
94
  case ControlType.WEEK: {
90
- return getInputDateValue(
91
- /** @type {HTMLInputElement} */ (controlNode),
95
+ return /** @type {T} */ (
96
+ getInputDateValue(/** @type {HTMLInputElement} */ (controlNode))
92
97
  );
93
98
  }
94
99
  case ControlType.DATETIME_LOCAL: {
95
- return getDatetimeLocalValue(
96
- /** @type {HTMLInputElement} */ (controlNode),
100
+ return /** @type {T} */ (
101
+ getDatetimeLocalValue(
102
+ /** @type {HTMLInputElement} */ (controlNode),
103
+ )
97
104
  );
98
105
  }
99
106
  case ControlType.FILE: {
100
- return getInputFileValue(
101
- /** @type {HTMLInputElement} */ (controlNode),
107
+ return /** @type {T} */ (
108
+ getInputFileValue(/** @type {HTMLInputElement} */ (controlNode))
102
109
  );
103
110
  }
104
111
  case ControlType.SELECT_MULTIPLE: {
105
- return getMultiSelectValues(
106
- /** @type {HTMLSelectElement} */ (controlNode),
112
+ return /** @type {T} */ (
113
+ getMultiSelectValues(
114
+ /** @type {HTMLSelectElement} */ (controlNode),
115
+ )
107
116
  );
108
117
  }
109
118
  case ControlType.FIELDSET: {
@@ -111,8 +120,10 @@ const getFormControlPayload = (controlNode) => {
111
120
  .../** @type {HTMLFieldSetElement} */ (controlNode).elements,
112
121
  ];
113
122
 
114
- return getFormControlsPayload(
115
- .../** @type {HTMLFormControlElement[]} */ (elements),
123
+ return /** @type {T} */ (
124
+ getFormControlsPayload(
125
+ .../** @type {HTMLFormControlElement[]} */ (elements),
126
+ )
116
127
  );
117
128
  }
118
129
  }