tnp-helpers 13.1.15 → 13.1.16

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.
Files changed (173) hide show
  1. package/app.js +3 -3
  2. package/browser/README.md +24 -24
  3. package/browser/esm2020/lib/angular.helper.mjs +88 -0
  4. package/browser/esm2020/lib/base-component.mjs +49 -49
  5. package/browser/esm2020/lib/base-formly-component.mjs +112 -112
  6. package/browser/esm2020/lib/condition-wait.mjs +45 -45
  7. package/browser/esm2020/lib/constants.mjs +7 -7
  8. package/browser/esm2020/lib/dual-component-ctrl.mjs +118 -118
  9. package/browser/esm2020/lib/firedev-models.mjs +3 -3
  10. package/browser/esm2020/lib/helpers-array-obj.mjs +82 -82
  11. package/browser/esm2020/lib/helpers-browser.mjs +46 -46
  12. package/browser/esm2020/lib/helpers-environment.mjs +32 -32
  13. package/browser/esm2020/lib/helpers-numbers.mjs +8 -8
  14. package/browser/esm2020/lib/helpers-strings-regexes.mjs +50 -50
  15. package/browser/esm2020/lib/helpers-strings.mjs +252 -252
  16. package/browser/esm2020/lib/helpers.mjs +284 -282
  17. package/browser/esm2020/lib/index.mjs +16 -15
  18. package/browser/esm2020/lib/long-press.directive.mjs +112 -112
  19. package/browser/esm2020/lib/project.mjs +429 -429
  20. package/browser/esm2020/lib/resize-service.mjs +21 -21
  21. package/browser/esm2020/public-api.mjs +1 -1
  22. package/browser/esm2020/tnp-helpers.mjs +4 -4
  23. package/browser/fesm2015/tnp-helpers.mjs +1680 -1591
  24. package/browser/fesm2020/tnp-helpers.mjs +1670 -1581
  25. package/browser/lib/angular.helper.d.ts +37 -0
  26. package/browser/lib/base-component.d.ts +16 -16
  27. package/browser/lib/base-formly-component.d.ts +30 -30
  28. package/browser/lib/condition-wait.d.ts +7 -7
  29. package/browser/lib/constants.d.ts +5 -5
  30. package/browser/lib/dual-component-ctrl.d.ts +24 -24
  31. package/browser/lib/firedev-models.d.ts +12 -12
  32. package/browser/lib/helpers-array-obj.d.ts +14 -14
  33. package/browser/lib/helpers-browser.d.ts +10 -10
  34. package/browser/lib/helpers-environment.d.ts +4 -4
  35. package/browser/lib/helpers-numbers.d.ts +2 -2
  36. package/browser/lib/helpers-strings-regexes.d.ts +27 -27
  37. package/browser/lib/helpers-strings.d.ts +49 -49
  38. package/browser/lib/helpers.d.ts +31 -29
  39. package/browser/lib/index.d.ts +11 -10
  40. package/browser/lib/long-press.directive.d.ts +24 -24
  41. package/browser/lib/project.d.ts +94 -94
  42. package/browser/lib/resize-service.d.ts +8 -8
  43. package/browser/tnp-helpers.d.ts +4 -4
  44. package/client/README.md +24 -24
  45. package/client/esm2020/lib/angular.helper.mjs +88 -0
  46. package/client/esm2020/lib/base-component.mjs +49 -49
  47. package/client/esm2020/lib/base-formly-component.mjs +112 -112
  48. package/client/esm2020/lib/condition-wait.mjs +45 -45
  49. package/client/esm2020/lib/constants.mjs +7 -7
  50. package/client/esm2020/lib/dual-component-ctrl.mjs +118 -118
  51. package/client/esm2020/lib/firedev-models.mjs +3 -3
  52. package/client/esm2020/lib/helpers-array-obj.mjs +82 -82
  53. package/client/esm2020/lib/helpers-browser.mjs +46 -46
  54. package/client/esm2020/lib/helpers-environment.mjs +32 -32
  55. package/client/esm2020/lib/helpers-numbers.mjs +8 -8
  56. package/client/esm2020/lib/helpers-strings-regexes.mjs +50 -50
  57. package/client/esm2020/lib/helpers-strings.mjs +252 -252
  58. package/client/esm2020/lib/helpers.mjs +284 -282
  59. package/client/esm2020/lib/index.mjs +16 -15
  60. package/client/esm2020/lib/long-press.directive.mjs +112 -112
  61. package/client/esm2020/lib/project.mjs +429 -429
  62. package/client/esm2020/lib/resize-service.mjs +21 -21
  63. package/client/esm2020/public-api.mjs +1 -1
  64. package/client/esm2020/tnp-helpers.mjs +4 -4
  65. package/client/fesm2015/tnp-helpers.mjs +1680 -1591
  66. package/client/fesm2020/tnp-helpers.mjs +1670 -1581
  67. package/client/lib/angular.helper.d.ts +37 -0
  68. package/client/lib/base-component.d.ts +16 -16
  69. package/client/lib/base-formly-component.d.ts +30 -30
  70. package/client/lib/condition-wait.d.ts +7 -7
  71. package/client/lib/constants.d.ts +5 -5
  72. package/client/lib/dual-component-ctrl.d.ts +24 -24
  73. package/client/lib/firedev-models.d.ts +12 -12
  74. package/client/lib/helpers-array-obj.d.ts +14 -14
  75. package/client/lib/helpers-browser.d.ts +10 -10
  76. package/client/lib/helpers-environment.d.ts +4 -4
  77. package/client/lib/helpers-numbers.d.ts +2 -2
  78. package/client/lib/helpers-strings-regexes.d.ts +27 -27
  79. package/client/lib/helpers-strings.d.ts +49 -49
  80. package/client/lib/helpers.d.ts +31 -29
  81. package/client/lib/index.d.ts +11 -10
  82. package/client/lib/long-press.directive.d.ts +24 -24
  83. package/client/lib/project.d.ts +94 -94
  84. package/client/lib/resize-service.d.ts +8 -8
  85. package/client/tnp-helpers.d.ts +4 -4
  86. package/index.d.ts +1 -1
  87. package/lib/angular.helper.d.ts +36 -22
  88. package/lib/angular.helper.js +3 -47
  89. package/lib/base-component.d.ts +13 -13
  90. package/lib/base-component.js +3 -3
  91. package/lib/base-formly-component.d.ts +27 -27
  92. package/lib/base-formly-component.js +3 -3
  93. package/lib/condition-wait.d.ts +8 -8
  94. package/lib/constants.d.ts +6 -6
  95. package/lib/dual-component-ctrl.d.ts +24 -24
  96. package/lib/dual-component-ctrl.js +3 -3
  97. package/lib/firedev-models.d.ts +13 -13
  98. package/lib/git-project.d.ts +45 -45
  99. package/lib/helpers-array-obj.d.ts +15 -15
  100. package/lib/helpers-browser.d.ts +11 -11
  101. package/lib/helpers-cli-tool.backend.d.ts +55 -55
  102. package/lib/helpers-dependencies.backend.d.ts +11 -11
  103. package/lib/helpers-environment.d.ts +5 -5
  104. package/lib/helpers-file-folders.backend.d.ts +83 -83
  105. package/lib/helpers-git.backend.d.ts +43 -43
  106. package/lib/helpers-json5.backend.d.ts +16 -16
  107. package/lib/helpers-morphi-framework.backend.d.ts +4 -4
  108. package/lib/helpers-network.backend.d.ts +8 -8
  109. package/lib/helpers-npm.backend.d.ts +3 -3
  110. package/lib/helpers-numbers.d.ts +3 -3
  111. package/lib/helpers-path.backend.d.ts +7 -7
  112. package/lib/helpers-process.backend.d.ts +54 -54
  113. package/lib/helpers-strings-regexes.d.ts +28 -28
  114. package/lib/helpers-strings.d.ts +50 -50
  115. package/lib/helpers-system-terminal.backend.d.ts +5 -5
  116. package/lib/helpers-vscode.backend.d.ts +5 -5
  117. package/lib/helpers.d.ts +72 -70
  118. package/lib/helpers.js +2 -0
  119. package/lib/index.d.ts +12 -11
  120. package/lib/index.js +1 -0
  121. package/lib/long-press.directive.d.ts +22 -22
  122. package/lib/merge-helpers.backend.d.ts +23 -23
  123. package/lib/project.d.ts +97 -97
  124. package/lib/resize-service.d.ts +6 -6
  125. package/lib/ts-code/index.d.ts +1 -1
  126. package/lib/ts-code/ts-code-extractor.d.ts +14 -14
  127. package/lib/ts-code/ts-code-modifier.backend.d.ts +12 -12
  128. package/package.json +2 -2
  129. package/package.json_devDependencies.json +222 -222
  130. package/package.json_tnp.json5 +44 -44
  131. package/tmp-environment.json +8 -8
  132. package/websql/README.md +24 -24
  133. package/websql/esm2020/lib/angular.helper.mjs +88 -0
  134. package/websql/esm2020/lib/base-component.mjs +49 -49
  135. package/websql/esm2020/lib/base-formly-component.mjs +112 -112
  136. package/websql/esm2020/lib/condition-wait.mjs +45 -45
  137. package/websql/esm2020/lib/constants.mjs +7 -7
  138. package/websql/esm2020/lib/dual-component-ctrl.mjs +118 -118
  139. package/websql/esm2020/lib/firedev-models.mjs +3 -3
  140. package/websql/esm2020/lib/helpers-array-obj.mjs +82 -82
  141. package/websql/esm2020/lib/helpers-browser.mjs +46 -46
  142. package/websql/esm2020/lib/helpers-environment.mjs +32 -32
  143. package/websql/esm2020/lib/helpers-numbers.mjs +8 -8
  144. package/websql/esm2020/lib/helpers-strings-regexes.mjs +50 -50
  145. package/websql/esm2020/lib/helpers-strings.mjs +252 -252
  146. package/websql/esm2020/lib/helpers.mjs +284 -282
  147. package/websql/esm2020/lib/index.mjs +16 -15
  148. package/websql/esm2020/lib/long-press.directive.mjs +112 -112
  149. package/websql/esm2020/lib/project.mjs +429 -429
  150. package/websql/esm2020/lib/resize-service.mjs +21 -21
  151. package/websql/esm2020/public-api.mjs +1 -1
  152. package/websql/esm2020/tnp-helpers.mjs +4 -4
  153. package/websql/fesm2015/tnp-helpers.mjs +1680 -1591
  154. package/websql/fesm2020/tnp-helpers.mjs +1670 -1581
  155. package/websql/lib/angular.helper.d.ts +37 -0
  156. package/websql/lib/base-component.d.ts +16 -16
  157. package/websql/lib/base-formly-component.d.ts +30 -30
  158. package/websql/lib/condition-wait.d.ts +7 -7
  159. package/websql/lib/constants.d.ts +5 -5
  160. package/websql/lib/dual-component-ctrl.d.ts +24 -24
  161. package/websql/lib/firedev-models.d.ts +12 -12
  162. package/websql/lib/helpers-array-obj.d.ts +14 -14
  163. package/websql/lib/helpers-browser.d.ts +10 -10
  164. package/websql/lib/helpers-environment.d.ts +4 -4
  165. package/websql/lib/helpers-numbers.d.ts +2 -2
  166. package/websql/lib/helpers-strings-regexes.d.ts +27 -27
  167. package/websql/lib/helpers-strings.d.ts +49 -49
  168. package/websql/lib/helpers.d.ts +31 -29
  169. package/websql/lib/index.d.ts +11 -10
  170. package/websql/lib/long-press.directive.d.ts +24 -24
  171. package/websql/lib/project.d.ts +94 -94
  172. package/websql/lib/resize-service.d.ts +8 -8
  173. package/websql/tnp-helpers.d.ts +4 -4
@@ -2,6 +2,7 @@ import { _, CoreHelpers } from 'tnp-core/websql';
2
2
  import * as fuzzy from 'fuzzy';
3
3
  import { CLASS } from 'typescript-class-helpers/websql';
4
4
  import { Morphi } from 'morphi/websql';
5
+ import { Subject } from 'rxjs';
5
6
  import * as i0 from '@angular/core';
6
7
  import { Component, Input, EventEmitter, Output, Injectable, Directive, HostBinding, HostListener } from '@angular/core';
7
8
  import { NavigationEnd } from '@angular/router';
@@ -9,1621 +10,1709 @@ import { FieldType } from '@ngx-formly/core';
9
10
  import { Log, Level } from 'ng2-logger/websql';
10
11
  import * as elementResizeDetectorMaker from 'element-resize-detector';
11
12
 
12
- class HelpersArrayObj {
13
- from(s) {
14
- if (_.isArray(s)) {
15
- return s;
16
- }
17
- if (_.isString(s)) {
18
- return s.split(' ');
19
- }
20
- }
21
- second(arr) {
22
- if (!Array.isArray(arr) || arr.length < 2) {
23
- return void 0;
24
- }
25
- return arr[1];
26
- }
27
- arrayMoveElementBefore(arr, a, b, prop) {
28
- let indexA = prop ? arr.findIndex(elem => elem[prop] === a[prop]) : arr.indexOf(a);
29
- _.pullAt(arr, indexA);
30
- let indexB = prop ? arr.findIndex(elem => elem[prop] === b[prop]) : arr.indexOf(b);
31
- if (indexB === 0) {
32
- arr.unshift(a);
33
- }
34
- else {
35
- arr.splice(indexB - 1, 0, a);
36
- }
37
- return arr;
38
- }
39
- arrayMoveElementAfterB(arr, a, b, prop) {
40
- let indexA = prop ? arr.findIndex(elem => elem[prop] === a[prop]) : arr.indexOf(a);
41
- _.pullAt(arr, indexA);
42
- let indexB = prop ? arr.findIndex(elem => elem[prop] === b[prop]) : arr.indexOf(b);
43
- if (indexB === arr.length - 1) {
44
- arr.push(a);
45
- }
46
- else {
47
- arr.splice(indexB + 1, 0, a);
48
- }
49
- return arr;
50
- }
51
- uniqArray(array, uniqueProperty) {
52
- var seen = {};
53
- return array
54
- .filter(f => !!f)
55
- .filter(function (item) {
56
- return seen.hasOwnProperty(uniqueProperty ? item[uniqueProperty] : item) ? false
57
- : (seen[uniqueProperty ? item[uniqueProperty] : item] = true);
58
- });
59
- }
60
- sortKeys(obj) {
61
- if (_.isArray(obj)) {
62
- return obj.map(Helpers.arrays.sortKeys);
63
- }
64
- if (_.isObject(obj)) {
65
- return _.fromPairs(_.keys(obj).sort().map(key => [key, Helpers.arrays.sortKeys(obj[key])]));
66
- }
67
- return obj;
68
- }
69
- ;
70
- /**
71
- * Fuzzy search
72
- */
73
- fuzzy(query, list, valueFn) {
74
- const resultsFuzzy = fuzzy.filter(query, list.map(k => valueFn ? valueFn(k) : k));
75
- const resultsFuzzyKebab = fuzzy.filter(_.kebabCase(query), list.map(k => _.kebabCase((valueFn ? valueFn(k) : k))));
76
- const matches = resultsFuzzy.map((el) => el.string);
77
- const matchesKebab = resultsFuzzyKebab.map((el) => el.string);
78
- const results = (resultsFuzzy.length === 0) ? [] : list.filter(k => {
79
- return matches.includes((valueFn ? valueFn(k) : k));
80
- });
81
- if (matches.length === 0 && matchesKebab.length > 0) {
82
- const m = list.find(k => _.kebabCase((valueFn ? valueFn(k) : k)) === _.first(matchesKebab));
83
- results.push(m);
84
- matches.push((valueFn ? valueFn(m) : m));
85
- }
86
- return { matches, results };
87
- }
88
- }
89
- ;
13
+ class HelpersArrayObj {
14
+ from(s) {
15
+ if (_.isArray(s)) {
16
+ return s;
17
+ }
18
+ if (_.isString(s)) {
19
+ return s.split(' ');
20
+ }
21
+ }
22
+ second(arr) {
23
+ if (!Array.isArray(arr) || arr.length < 2) {
24
+ return void 0;
25
+ }
26
+ return arr[1];
27
+ }
28
+ arrayMoveElementBefore(arr, a, b, prop) {
29
+ let indexA = prop ? arr.findIndex(elem => elem[prop] === a[prop]) : arr.indexOf(a);
30
+ _.pullAt(arr, indexA);
31
+ let indexB = prop ? arr.findIndex(elem => elem[prop] === b[prop]) : arr.indexOf(b);
32
+ if (indexB === 0) {
33
+ arr.unshift(a);
34
+ }
35
+ else {
36
+ arr.splice(indexB - 1, 0, a);
37
+ }
38
+ return arr;
39
+ }
40
+ arrayMoveElementAfterB(arr, a, b, prop) {
41
+ let indexA = prop ? arr.findIndex(elem => elem[prop] === a[prop]) : arr.indexOf(a);
42
+ _.pullAt(arr, indexA);
43
+ let indexB = prop ? arr.findIndex(elem => elem[prop] === b[prop]) : arr.indexOf(b);
44
+ if (indexB === arr.length - 1) {
45
+ arr.push(a);
46
+ }
47
+ else {
48
+ arr.splice(indexB + 1, 0, a);
49
+ }
50
+ return arr;
51
+ }
52
+ uniqArray(array, uniqueProperty) {
53
+ var seen = {};
54
+ return array
55
+ .filter(f => !!f)
56
+ .filter(function (item) {
57
+ return seen.hasOwnProperty(uniqueProperty ? item[uniqueProperty] : item) ? false
58
+ : (seen[uniqueProperty ? item[uniqueProperty] : item] = true);
59
+ });
60
+ }
61
+ sortKeys(obj) {
62
+ if (_.isArray(obj)) {
63
+ return obj.map(Helpers.arrays.sortKeys);
64
+ }
65
+ if (_.isObject(obj)) {
66
+ return _.fromPairs(_.keys(obj).sort().map(key => [key, Helpers.arrays.sortKeys(obj[key])]));
67
+ }
68
+ return obj;
69
+ }
70
+ ;
71
+ /**
72
+ * Fuzzy search
73
+ */
74
+ fuzzy(query, list, valueFn) {
75
+ const resultsFuzzy = fuzzy.filter(query, list.map(k => valueFn ? valueFn(k) : k));
76
+ const resultsFuzzyKebab = fuzzy.filter(_.kebabCase(query), list.map(k => _.kebabCase((valueFn ? valueFn(k) : k))));
77
+ const matches = resultsFuzzy.map((el) => el.string);
78
+ const matchesKebab = resultsFuzzyKebab.map((el) => el.string);
79
+ const results = (resultsFuzzy.length === 0) ? [] : list.filter(k => {
80
+ return matches.includes((valueFn ? valueFn(k) : k));
81
+ });
82
+ if (matches.length === 0 && matchesKebab.length > 0) {
83
+ const m = list.find(k => _.kebabCase((valueFn ? valueFn(k) : k)) === _.first(matchesKebab));
84
+ results.push(m);
85
+ matches.push((valueFn ? valueFn(m) : m));
86
+ }
87
+ return { matches, results };
88
+ }
89
+ }
90
+ ;
90
91
  ({}); // @--end-of-file-for-module=tnp-helpers lib/helpers-array-obj.ts
91
92
 
92
- class HelpersStringsRegexes {
93
- escapeStringForRegEx(s) {
94
- return s.replace(/[-\/\\^$*+?.()|[\]{}]/g, '\\$&');
95
- }
96
- matchExactOnce(s, regex) {
97
- if (!_.isString(s) || !_.isRegExp(regex)) {
98
- return void 0;
99
- }
100
- const result = s.match(regex);
101
- if (_.isNil(result)) {
102
- return void 0;
103
- }
104
- return result.length >= 1 ? _.first(result) : void 0;
105
- }
106
- get regex() {
107
- return {
108
- /**
109
- * mathes
110
- * xxx.xxx.xxx.xxx
111
- * xxx.xxx.xxx.xxx:port
112
- * http://xxx.xxx.xxx.xxx:port
113
- * http://xxx.xxx.xxx.xxx
114
- * https://xxx.xxx.xxx.xxx:port
115
- * https://xxx.xxx.xxx.xxx *
116
- */
117
- get forStringWithIpHost() {
118
- const regex = /(http(s)?\:\/\/)?(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)(\:[0-9]+)?/;
119
- return regex;
120
- },
121
- /**
122
- * mathes
123
- * http://domain.com:port
124
- * http://domain.com
125
- * http://domain:port
126
- * http://domain
127
- * https://domain.com:port
128
- * https://domain.com
129
- * https://domain:port
130
- * https://domain
131
- */
132
- get forStringWithDomainHost() {
133
- const regex = /(((http(s)?\:\/\/)?[a-zA-Z0-9][a-zA-Z0-9-]{1,61}[a-zA-Z0-9](?:\.[a-zA-Z]{2,})+(\:[0-9]+)?)|((http(s)?\:\/\/)[a-zA-Z0-9-]{1,61}))/;
134
- return regex;
135
- }
136
- };
137
- }
138
- }
139
- ;
93
+ class HelpersStringsRegexes {
94
+ escapeStringForRegEx(s) {
95
+ return s.replace(/[-\/\\^$*+?.()|[\]{}]/g, '\\$&');
96
+ }
97
+ matchExactOnce(s, regex) {
98
+ if (!_.isString(s) || !_.isRegExp(regex)) {
99
+ return void 0;
100
+ }
101
+ const result = s.match(regex);
102
+ if (_.isNil(result)) {
103
+ return void 0;
104
+ }
105
+ return result.length >= 1 ? _.first(result) : void 0;
106
+ }
107
+ get regex() {
108
+ return {
109
+ /**
110
+ * mathes
111
+ * xxx.xxx.xxx.xxx
112
+ * xxx.xxx.xxx.xxx:port
113
+ * http://xxx.xxx.xxx.xxx:port
114
+ * http://xxx.xxx.xxx.xxx
115
+ * https://xxx.xxx.xxx.xxx:port
116
+ * https://xxx.xxx.xxx.xxx *
117
+ */
118
+ get forStringWithIpHost() {
119
+ const regex = /(http(s)?\:\/\/)?(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)(\:[0-9]+)?/;
120
+ return regex;
121
+ },
122
+ /**
123
+ * mathes
124
+ * http://domain.com:port
125
+ * http://domain.com
126
+ * http://domain:port
127
+ * http://domain
128
+ * https://domain.com:port
129
+ * https://domain.com
130
+ * https://domain:port
131
+ * https://domain
132
+ */
133
+ get forStringWithDomainHost() {
134
+ const regex = /(((http(s)?\:\/\/)?[a-zA-Z0-9][a-zA-Z0-9-]{1,61}[a-zA-Z0-9](?:\.[a-zA-Z]{2,})+(\:[0-9]+)?)|((http(s)?\:\/\/)[a-zA-Z0-9-]{1,61}))/;
135
+ return regex;
136
+ }
137
+ };
138
+ }
139
+ }
140
+ ;
140
141
  ({}); // @--end-of-file-for-module=tnp-helpers lib/helpers-strings-regexes.ts
141
142
 
142
- /* */
143
- /* */
144
- /* */
145
- /* */
146
- class HelpersEnvironment {
147
- environmentName(filename, local_env_name) {
148
- /* */
149
- /* */
150
- /* */
151
- /* */
152
- /* */
153
- /* */
154
- }
155
- isValidGitRepuUrl(url) {
156
- const regex = /^([A-Za-z0-9]+@|http(|s)\:\/\/)([A-Za-z0-9.]+(:\d+)?)(?::|\/)([\d\/\w.-]+?)(\.git)?$/;
157
- const res = regex.test(url);
158
- return res;
159
- }
160
- isValidIp(ip) {
161
- if (!_.isString(ip)) {
162
- return false;
163
- }
164
- ip = ip.trim();
165
- if (ip === 'localhost') {
166
- return true;
167
- }
168
- return /^(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)$/.test(ip);
169
- }
170
- }
171
- ;
143
+ /* */
144
+ /* */
145
+ /* */
146
+ /* */
147
+ class HelpersEnvironment {
148
+ environmentName(filename, local_env_name) {
149
+ /* */
150
+ /* */
151
+ /* */
152
+ /* */
153
+ /* */
154
+ /* */
155
+ }
156
+ isValidGitRepuUrl(url) {
157
+ const regex = /^([A-Za-z0-9]+@|http(|s)\:\/\/)([A-Za-z0-9.]+(:\d+)?)(?::|\/)([\d\/\w.-]+?)(\.git)?$/;
158
+ const res = regex.test(url);
159
+ return res;
160
+ }
161
+ isValidIp(ip) {
162
+ if (!_.isString(ip)) {
163
+ return false;
164
+ }
165
+ ip = ip.trim();
166
+ if (ip === 'localhost') {
167
+ return true;
168
+ }
169
+ return /^(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)$/.test(ip);
170
+ }
171
+ }
172
+ ;
172
173
  ({}); // @--end-of-file-for-module=tnp-helpers lib/helpers-environment.ts
173
174
 
174
- class HelpersStrings {
175
- /**
176
- * Example:
177
- *
178
- * const result = interpolateString("I'm {age} years old!")
179
- * .withParameters({ age: 29 });
180
- *
181
- * const result = interpolateString("The {a} says {n}, {n}, {n}!")
182
- * .withParameters({ a: 'cow', n: 'moo' });
183
- *
184
- *
185
- * @param value string to interpolate
186
- * @param parameters object with parametes
187
- */
188
- interpolateString(value) {
189
- if (typeof value !== 'string') {
190
- Helpers.warn('[ss-logic][helper] Value for interpolation is not string: ', value);
191
- return value;
192
- }
193
- return {
194
- withParameters(parameters) {
195
- if (typeof parameters !== 'object') {
196
- Helpers.log(parameters);
197
- Helpers.warn('[ss-logic][helper] Parameters are not a object: ');
198
- return value;
199
- }
200
- return value.replace(/{([^{}]*)}/g, function (a, b) {
201
- var r = parameters[b];
202
- return typeof r === 'string' || typeof r === 'number' ? r : a;
203
- });
204
- }
205
- };
206
- }
207
- numValue(pixelsCss) {
208
- return parseInt(pixelsCss.replace('px', ''));
209
- }
210
- /**
211
- * examples:
212
- * 'aa bb bb' => ['aa','bb','cc'],
213
- * 'aa' => ['aa']
214
- * ['aa'] => ['aa']
215
- */
216
- splitIfNeed(stringOrArr) {
217
- let res = [];
218
- if (_.isArray(stringOrArr)) {
219
- res = stringOrArr.map(s => {
220
- return s.trim();
221
- });
222
- }
223
- if (_.isString(stringOrArr)) {
224
- res = stringOrArr.split(/\s*[\s,]\s*/);
225
- }
226
- return res.filter(f => !!f && (f.trim() !== ''));
227
- }
228
- removeDoubleOrMoreEmptyLines(s) {
229
- s = s?.split('\n').map(f => f.trimRight()).join('\n');
230
- return s?.replace(/(\r\n|\r|\n){2,}/g, '$1\n');
231
- }
232
- /**
233
- *
234
- * https://stackoverflow.com/a/57129703/1345101
235
- *
236
- * Returns the plural of an English word.
237
- *
238
- * @export
239
- * @param {string} word
240
- * @param {number} [amount]
241
- * @returns {string}
242
- */
243
- plural(word, amount) {
244
- if (amount !== undefined && amount === 1) {
245
- return word;
246
- }
247
- const plural = {
248
- '(quiz)$': "$1zes",
249
- '^(ox)$': "$1en",
250
- '([m|l])ouse$': "$1ice",
251
- '(matr|vert|ind)ix|ex$': "$1ices",
252
- '(x|ch|ss|sh)$': "$1es",
253
- '([^aeiouy]|qu)y$': "$1ies",
254
- '(hive)$': "$1s",
255
- '(?:([^f])fe|([lr])f)$': "$1$2ves",
256
- '(shea|lea|loa|thie)f$': "$1ves",
257
- 'sis$': "ses",
258
- '([ti])um$': "$1a",
259
- '(tomat|potat|ech|her|vet)o$': "$1oes",
260
- '(bu)s$': "$1ses",
261
- '(alias)$': "$1es",
262
- '(octop)us$': "$1i",
263
- '(ax|test)is$': "$1es",
264
- '(us)$': "$1es",
265
- '([^s]+)$': "$1s"
266
- };
267
- const irregular = {
268
- 'move': 'moves',
269
- 'foot': 'feet',
270
- 'goose': 'geese',
271
- 'sex': 'sexes',
272
- 'child': 'children',
273
- 'man': 'men',
274
- 'tooth': 'teeth',
275
- 'person': 'people'
276
- };
277
- const uncountable = [
278
- 'sheep',
279
- 'fish',
280
- 'deer',
281
- 'moose',
282
- 'series',
283
- 'species',
284
- 'money',
285
- 'rice',
286
- 'information',
287
- 'equipment',
288
- 'bison',
289
- 'cod',
290
- 'offspring',
291
- 'pike',
292
- 'salmon',
293
- 'shrimp',
294
- 'swine',
295
- 'trout',
296
- 'aircraft',
297
- 'hovercraft',
298
- 'spacecraft',
299
- 'sugar',
300
- 'tuna',
301
- 'you',
302
- 'wood'
303
- ];
304
- if (uncountable.indexOf(word.toLowerCase()) >= 0) {
305
- return word;
306
- }
307
- for (const w in irregular) {
308
- const pattern = new RegExp(`${w}$`, 'i');
309
- const replace = irregular[w];
310
- if (pattern.test(word)) {
311
- return word.replace(pattern, replace);
312
- }
313
- }
314
- for (const reg in plural) {
315
- const pattern = new RegExp(reg, 'i');
316
- if (pattern.test(word)) {
317
- return word.replace(pattern, plural[reg]);
318
- }
319
- }
320
- return word;
321
- }
322
- /**
323
- * https://stackoverflow.com/a/57129703/1345101
324
- *
325
- * Returns the singular of an English word.
326
- *
327
- * @export
328
- * @param {string} word
329
- * @param {number} [amount]
330
- * @returns {string}
331
- */
332
- singular(word, amount) {
333
- if (amount !== undefined && amount !== 1) {
334
- return word;
335
- }
336
- const singular = {
337
- '(quiz)zes$': "$1",
338
- '(matr)ices$': "$1ix",
339
- '(vert|ind)ices$': "$1ex",
340
- '^(ox)en$': "$1",
341
- '(alias)es$': "$1",
342
- '(octop|vir)i$': "$1us",
343
- '(cris|ax|test)es$': "$1is",
344
- '(shoe)s$': "$1",
345
- '(o)es$': "$1",
346
- '(bus)es$': "$1",
347
- '([m|l])ice$': "$1ouse",
348
- '(x|ch|ss|sh)es$': "$1",
349
- '(m)ovies$': "$1ovie",
350
- '(s)eries$': "$1eries",
351
- '([^aeiouy]|qu)ies$': "$1y",
352
- '([lr])ves$': "$1f",
353
- '(tive)s$': "$1",
354
- '(hive)s$': "$1",
355
- '(li|wi|kni)ves$': "$1fe",
356
- '(shea|loa|lea|thie)ves$': "$1f",
357
- '(^analy)ses$': "$1sis",
358
- '((a)naly|(b)a|(d)iagno|(p)arenthe|(p)rogno|(s)ynop|(t)he)ses$': "$1$2sis",
359
- '([ti])a$': "$1um",
360
- '(n)ews$': "$1ews",
361
- '(h|bl)ouses$': "$1ouse",
362
- '(corpse)s$': "$1",
363
- '(us)es$': "$1",
364
- 's$': ""
365
- };
366
- const irregular = {
367
- 'move': 'moves',
368
- 'foot': 'feet',
369
- 'goose': 'geese',
370
- 'sex': 'sexes',
371
- 'child': 'children',
372
- 'man': 'men',
373
- 'tooth': 'teeth',
374
- 'person': 'people'
375
- };
376
- const uncountable = [
377
- 'sheep',
378
- 'fish',
379
- 'deer',
380
- 'moose',
381
- 'series',
382
- 'species',
383
- 'money',
384
- 'rice',
385
- 'information',
386
- 'equipment',
387
- 'bison',
388
- 'cod',
389
- 'offspring',
390
- 'pike',
391
- 'salmon',
392
- 'shrimp',
393
- 'swine',
394
- 'trout',
395
- 'aircraft',
396
- 'hovercraft',
397
- 'spacecraft',
398
- 'sugar',
399
- 'tuna',
400
- 'you',
401
- 'wood'
402
- ];
403
- if (uncountable.indexOf(word.toLowerCase()) >= 0) {
404
- return word;
405
- }
406
- for (const w in irregular) {
407
- const pattern = new RegExp(`${irregular[w]}$`, 'i');
408
- const replace = w;
409
- if (pattern.test(word)) {
410
- return word.replace(pattern, replace);
411
- }
412
- }
413
- for (const reg in singular) {
414
- const pattern = new RegExp(reg, 'i');
415
- if (pattern.test(word)) {
416
- return word.replace(pattern, singular[reg]);
417
- }
418
- }
419
- return word;
420
- }
421
- }
422
- ;
175
+ class HelpersStrings {
176
+ /**
177
+ * Example:
178
+ *
179
+ * const result = interpolateString("I'm {age} years old!")
180
+ * .withParameters({ age: 29 });
181
+ *
182
+ * const result = interpolateString("The {a} says {n}, {n}, {n}!")
183
+ * .withParameters({ a: 'cow', n: 'moo' });
184
+ *
185
+ *
186
+ * @param value string to interpolate
187
+ * @param parameters object with parametes
188
+ */
189
+ interpolateString(value) {
190
+ if (typeof value !== 'string') {
191
+ Helpers.warn('[ss-logic][helper] Value for interpolation is not string: ', value);
192
+ return value;
193
+ }
194
+ return {
195
+ withParameters(parameters) {
196
+ if (typeof parameters !== 'object') {
197
+ Helpers.log(parameters);
198
+ Helpers.warn('[ss-logic][helper] Parameters are not a object: ');
199
+ return value;
200
+ }
201
+ return value.replace(/{([^{}]*)}/g, function (a, b) {
202
+ var r = parameters[b];
203
+ return typeof r === 'string' || typeof r === 'number' ? r : a;
204
+ });
205
+ }
206
+ };
207
+ }
208
+ numValue(pixelsCss) {
209
+ return parseInt(pixelsCss.replace('px', ''));
210
+ }
211
+ /**
212
+ * examples:
213
+ * 'aa bb bb' => ['aa','bb','cc'],
214
+ * 'aa' => ['aa']
215
+ * ['aa'] => ['aa']
216
+ */
217
+ splitIfNeed(stringOrArr) {
218
+ let res = [];
219
+ if (_.isArray(stringOrArr)) {
220
+ res = stringOrArr.map(s => {
221
+ return s.trim();
222
+ });
223
+ }
224
+ if (_.isString(stringOrArr)) {
225
+ res = stringOrArr.split(/\s*[\s,]\s*/);
226
+ }
227
+ return res.filter(f => !!f && (f.trim() !== ''));
228
+ }
229
+ removeDoubleOrMoreEmptyLines(s) {
230
+ s = s?.split('\n').map(f => f.trimRight()).join('\n');
231
+ return s?.replace(/(\r\n|\r|\n){2,}/g, '$1\n');
232
+ }
233
+ /**
234
+ *
235
+ * https://stackoverflow.com/a/57129703/1345101
236
+ *
237
+ * Returns the plural of an English word.
238
+ *
239
+ * @export
240
+ * @param {string} word
241
+ * @param {number} [amount]
242
+ * @returns {string}
243
+ */
244
+ plural(word, amount) {
245
+ if (amount !== undefined && amount === 1) {
246
+ return word;
247
+ }
248
+ const plural = {
249
+ '(quiz)$': "$1zes",
250
+ '^(ox)$': "$1en",
251
+ '([m|l])ouse$': "$1ice",
252
+ '(matr|vert|ind)ix|ex$': "$1ices",
253
+ '(x|ch|ss|sh)$': "$1es",
254
+ '([^aeiouy]|qu)y$': "$1ies",
255
+ '(hive)$': "$1s",
256
+ '(?:([^f])fe|([lr])f)$': "$1$2ves",
257
+ '(shea|lea|loa|thie)f$': "$1ves",
258
+ 'sis$': "ses",
259
+ '([ti])um$': "$1a",
260
+ '(tomat|potat|ech|her|vet)o$': "$1oes",
261
+ '(bu)s$': "$1ses",
262
+ '(alias)$': "$1es",
263
+ '(octop)us$': "$1i",
264
+ '(ax|test)is$': "$1es",
265
+ '(us)$': "$1es",
266
+ '([^s]+)$': "$1s"
267
+ };
268
+ const irregular = {
269
+ 'move': 'moves',
270
+ 'foot': 'feet',
271
+ 'goose': 'geese',
272
+ 'sex': 'sexes',
273
+ 'child': 'children',
274
+ 'man': 'men',
275
+ 'tooth': 'teeth',
276
+ 'person': 'people'
277
+ };
278
+ const uncountable = [
279
+ 'sheep',
280
+ 'fish',
281
+ 'deer',
282
+ 'moose',
283
+ 'series',
284
+ 'species',
285
+ 'money',
286
+ 'rice',
287
+ 'information',
288
+ 'equipment',
289
+ 'bison',
290
+ 'cod',
291
+ 'offspring',
292
+ 'pike',
293
+ 'salmon',
294
+ 'shrimp',
295
+ 'swine',
296
+ 'trout',
297
+ 'aircraft',
298
+ 'hovercraft',
299
+ 'spacecraft',
300
+ 'sugar',
301
+ 'tuna',
302
+ 'you',
303
+ 'wood'
304
+ ];
305
+ if (uncountable.indexOf(word.toLowerCase()) >= 0) {
306
+ return word;
307
+ }
308
+ for (const w in irregular) {
309
+ const pattern = new RegExp(`${w}$`, 'i');
310
+ const replace = irregular[w];
311
+ if (pattern.test(word)) {
312
+ return word.replace(pattern, replace);
313
+ }
314
+ }
315
+ for (const reg in plural) {
316
+ const pattern = new RegExp(reg, 'i');
317
+ if (pattern.test(word)) {
318
+ return word.replace(pattern, plural[reg]);
319
+ }
320
+ }
321
+ return word;
322
+ }
323
+ /**
324
+ * https://stackoverflow.com/a/57129703/1345101
325
+ *
326
+ * Returns the singular of an English word.
327
+ *
328
+ * @export
329
+ * @param {string} word
330
+ * @param {number} [amount]
331
+ * @returns {string}
332
+ */
333
+ singular(word, amount) {
334
+ if (amount !== undefined && amount !== 1) {
335
+ return word;
336
+ }
337
+ const singular = {
338
+ '(quiz)zes$': "$1",
339
+ '(matr)ices$': "$1ix",
340
+ '(vert|ind)ices$': "$1ex",
341
+ '^(ox)en$': "$1",
342
+ '(alias)es$': "$1",
343
+ '(octop|vir)i$': "$1us",
344
+ '(cris|ax|test)es$': "$1is",
345
+ '(shoe)s$': "$1",
346
+ '(o)es$': "$1",
347
+ '(bus)es$': "$1",
348
+ '([m|l])ice$': "$1ouse",
349
+ '(x|ch|ss|sh)es$': "$1",
350
+ '(m)ovies$': "$1ovie",
351
+ '(s)eries$': "$1eries",
352
+ '([^aeiouy]|qu)ies$': "$1y",
353
+ '([lr])ves$': "$1f",
354
+ '(tive)s$': "$1",
355
+ '(hive)s$': "$1",
356
+ '(li|wi|kni)ves$': "$1fe",
357
+ '(shea|loa|lea|thie)ves$': "$1f",
358
+ '(^analy)ses$': "$1sis",
359
+ '((a)naly|(b)a|(d)iagno|(p)arenthe|(p)rogno|(s)ynop|(t)he)ses$': "$1$2sis",
360
+ '([ti])a$': "$1um",
361
+ '(n)ews$': "$1ews",
362
+ '(h|bl)ouses$': "$1ouse",
363
+ '(corpse)s$': "$1",
364
+ '(us)es$': "$1",
365
+ 's$': ""
366
+ };
367
+ const irregular = {
368
+ 'move': 'moves',
369
+ 'foot': 'feet',
370
+ 'goose': 'geese',
371
+ 'sex': 'sexes',
372
+ 'child': 'children',
373
+ 'man': 'men',
374
+ 'tooth': 'teeth',
375
+ 'person': 'people'
376
+ };
377
+ const uncountable = [
378
+ 'sheep',
379
+ 'fish',
380
+ 'deer',
381
+ 'moose',
382
+ 'series',
383
+ 'species',
384
+ 'money',
385
+ 'rice',
386
+ 'information',
387
+ 'equipment',
388
+ 'bison',
389
+ 'cod',
390
+ 'offspring',
391
+ 'pike',
392
+ 'salmon',
393
+ 'shrimp',
394
+ 'swine',
395
+ 'trout',
396
+ 'aircraft',
397
+ 'hovercraft',
398
+ 'spacecraft',
399
+ 'sugar',
400
+ 'tuna',
401
+ 'you',
402
+ 'wood'
403
+ ];
404
+ if (uncountable.indexOf(word.toLowerCase()) >= 0) {
405
+ return word;
406
+ }
407
+ for (const w in irregular) {
408
+ const pattern = new RegExp(`${irregular[w]}$`, 'i');
409
+ const replace = w;
410
+ if (pattern.test(word)) {
411
+ return word.replace(pattern, replace);
412
+ }
413
+ }
414
+ for (const reg in singular) {
415
+ const pattern = new RegExp(reg, 'i');
416
+ if (pattern.test(word)) {
417
+ return word.replace(pattern, singular[reg]);
418
+ }
419
+ }
420
+ return word;
421
+ }
422
+ }
423
+ ;
423
424
  ({}); // @--end-of-file-for-module=tnp-helpers lib/helpers-strings.ts
424
425
 
425
- async function conditionWait(conditionAndTimeout) {
426
- await waitFor(conditionAndTimeout);
427
- }
428
- function waitFor(arr, messageToShow = void 0) {
429
- return new Promise(async (resolve, reject) => {
430
- if (arr.length === 0) {
431
- resolve(void 0);
432
- }
433
- else {
434
- const check = arr.shift();
435
- if (_.isUndefined(check.timeoutCheck)) {
436
- check.timeoutCheck = 2000;
437
- }
438
- if (_.isUndefined(check.timeoutNext)) {
439
- check.timeoutNext = 4000;
440
- }
441
- const { timeoutCheck, timeoutNext, name } = check;
442
- const resultTrue = await Helpers.runSyncOrAsync(check.callback, check);
443
- if (resultTrue) {
444
- setTimeout(async () => {
445
- await waitFor(arr).then(() => {
446
- resolve(void 0);
447
- });
448
- }, timeoutNext);
449
- }
450
- else {
451
- arr.unshift(check);
452
- if (!messageToShow || check.errorMessage !== messageToShow) {
453
- Helpers.info(check.errorMessage);
454
- }
455
- else {
456
- }
457
- setTimeout(async () => {
458
- await waitFor(arr, check.errorMessage).then(() => {
459
- resolve(void 0);
460
- });
461
- }, timeoutCheck);
462
- }
463
- }
464
- });
465
- }
466
- ;
426
+ async function conditionWait(conditionAndTimeout) {
427
+ await waitFor(conditionAndTimeout);
428
+ }
429
+ function waitFor(arr, messageToShow = void 0) {
430
+ return new Promise(async (resolve, reject) => {
431
+ if (arr.length === 0) {
432
+ resolve(void 0);
433
+ }
434
+ else {
435
+ const check = arr.shift();
436
+ if (_.isUndefined(check.timeoutCheck)) {
437
+ check.timeoutCheck = 2000;
438
+ }
439
+ if (_.isUndefined(check.timeoutNext)) {
440
+ check.timeoutNext = 4000;
441
+ }
442
+ const { timeoutCheck, timeoutNext, name } = check;
443
+ const resultTrue = await Helpers.runSyncOrAsync(check.callback, check);
444
+ if (resultTrue) {
445
+ setTimeout(async () => {
446
+ await waitFor(arr).then(() => {
447
+ resolve(void 0);
448
+ });
449
+ }, timeoutNext);
450
+ }
451
+ else {
452
+ arr.unshift(check);
453
+ if (!messageToShow || check.errorMessage !== messageToShow) {
454
+ Helpers.info(check.errorMessage);
455
+ }
456
+ else {
457
+ }
458
+ setTimeout(async () => {
459
+ await waitFor(arr, check.errorMessage).then(() => {
460
+ resolve(void 0);
461
+ });
462
+ }, timeoutCheck);
463
+ }
464
+ }
465
+ });
466
+ }
467
+ ;
467
468
  ({}); // @--end-of-file-for-module=tnp-helpers lib/condition-wait.ts
468
469
 
469
- class HelpersNumber {
470
- constructor() {
471
- this.randomInteger = (max, min) => Math.round(Math.random() * (max - min)) + min;
472
- }
473
- }
474
- ;
470
+ class HelpersNumber {
471
+ constructor() {
472
+ this.randomInteger = (max, min) => Math.round(Math.random() * (max - min)) + min;
473
+ }
474
+ }
475
+ ;
475
476
  ({}); // @--end-of-file-for-module=tnp-helpers lib/helpers-numbers.ts
476
477
 
477
- const key = Symbol('[firedev-helpers] helper browser key');
478
- class HelpersBrowaser {
479
- constructor(win) {
480
- this.init = (() => {
481
- const win = this.win;
482
- if (!win[key]) {
483
- win[key] = new HelpersBrowaser(win);
484
- }
485
- HelpersBrowaser.inst = win[key];
486
- })();
487
- win.addEventListener("beforeunload", (e) => {
488
- win.sessionStorage.tabId = this.tabId;
489
- return null;
490
- });
491
- setTimeout(() => {
492
- if (win.sessionStorage?.tabId) {
493
- // @ts-ignore
494
- this.tabId = Number(win.sessionStorage.tabId);
495
- win.sessionStorage.removeItem("tabId");
496
- }
497
- else {
498
- // @ts-ignore
499
- this.tabId = Math.floor(Math.random() * 1000000) + (new Date()).getTime();
500
- }
501
- HelpersBrowaser.callbacks.forEach((c) => {
502
- c(this);
503
- });
504
- });
505
- }
506
- static onInit(callback) {
507
- this.callbacks.push(callback);
508
- }
509
- get win() {
510
- let win = window;
511
- return win;
512
- }
513
- get tabIdSessionStorage() {
514
- return Number(this.win.sessionStorage?.tabId) || 0;
515
- }
516
- static get instance() {
517
- return HelpersBrowaser.inst;
518
- }
519
- }
520
- HelpersBrowaser.callbacks = [];
521
- ;
478
+ const key = Symbol('[firedev-helpers] helper browser key');
479
+ class HelpersBrowaser {
480
+ constructor(win) {
481
+ this.init = (() => {
482
+ const win = this.win;
483
+ if (!win[key]) {
484
+ win[key] = new HelpersBrowaser(win);
485
+ }
486
+ HelpersBrowaser.inst = win[key];
487
+ })();
488
+ win.addEventListener("beforeunload", (e) => {
489
+ win.sessionStorage.tabId = this.tabId;
490
+ return null;
491
+ });
492
+ setTimeout(() => {
493
+ if (win.sessionStorage?.tabId) {
494
+ // @ts-ignore
495
+ this.tabId = Number(win.sessionStorage.tabId);
496
+ win.sessionStorage.removeItem("tabId");
497
+ }
498
+ else {
499
+ // @ts-ignore
500
+ this.tabId = Math.floor(Math.random() * 1000000) + (new Date()).getTime();
501
+ }
502
+ HelpersBrowaser.callbacks.forEach((c) => {
503
+ c(this);
504
+ });
505
+ });
506
+ }
507
+ static onInit(callback) {
508
+ this.callbacks.push(callback);
509
+ }
510
+ get win() {
511
+ let win = window;
512
+ return win;
513
+ }
514
+ get tabIdSessionStorage() {
515
+ return Number(this.win.sessionStorage?.tabId) || 0;
516
+ }
517
+ static get instance() {
518
+ return HelpersBrowaser.inst;
519
+ }
520
+ }
521
+ HelpersBrowaser.callbacks = [];
522
+ ;
522
523
  ({}); // @--end-of-file-for-module=tnp-helpers lib/helpers-browser.ts
523
524
 
524
- function applyMixins(derivedCtor, baseCtors) {
525
- baseCtors.forEach(baseCtor => {
526
- Object.getOwnPropertyNames(baseCtor.prototype).forEach(name => {
527
- Object.defineProperty(derivedCtor.prototype, name, Object.getOwnPropertyDescriptor(baseCtor.prototype, name));
528
- });
529
- });
530
- }
531
- // @ts-ignore
532
- class HelpersTnp extends CoreHelpers {
533
- constructor(
534
- /* */
535
- /* */
536
- /* */
537
- /* */
538
- /* */
539
- /* */
540
- /* */
541
- /* */
542
- /* */
543
- /* */
544
- /* */
545
- /* */
546
- /* */
547
- arrays = new HelpersArrayObj(), strings = new HelpersStrings(), numbers = new HelpersNumber(), browser = HelpersBrowaser.instance) {
548
- super();
549
- this.arrays = arrays;
550
- this.strings = strings;
551
- this.numbers = numbers;
552
- this.browser = browser;
553
- this.conditionWait = conditionWait;
554
- /* */
555
- /* */
556
- /* */
557
- /* */
558
- /* */
559
- /* */
560
- /* */
561
- /* */
562
- /* */
563
- /* */
564
- /* */
565
- /* */
566
- /* */
567
- /* */
568
- /* */
569
- /* */
570
- /* */
571
- /* */
572
- /* */
573
- /* */
574
- /* */
575
- /* */
576
- /* */
577
- /* */
578
- /* */
579
- /* */
580
- /* */
581
- /* */
582
- /* */
583
- /* */
584
- /* */
585
- /* */
586
- /* */
587
- /* */
588
- /* */
589
- /* */
590
- /* */
591
- /* */
592
- /* */
593
- /* */
594
- /* */
595
- /* */
596
- /* */
597
- /* */
598
- /* */
599
- /* */
600
- /* */
601
- /* */
602
- /* */
603
- /* */
604
- /* */
605
- /* */
606
- /* */
607
- /* */
608
- /* */
609
- /* */
610
- /* */
611
- /* */
612
- /* */
613
- /* */
614
- /* */
615
- /* */
616
- /* */
617
- /* */
618
- /* */
619
- /* */
620
- /* */
621
- /* */
622
- /* */
623
- /* */
624
- /* */
625
- /* */
626
- /* */
627
- /* */
628
- /* */
629
- /* */
630
- /* */
631
- /* */
632
- this.applyMixins = applyMixins;
633
- }
634
- static get Instance() {
635
- if (!HelpersTnp._instance) {
636
- HelpersTnp._instance = new HelpersTnp();
637
- }
638
- return HelpersTnp._instance;
639
- }
640
- CLIWRAP(f, name) {
641
- CLASS.setName(f, name);
642
- return f;
643
- }
644
- /* */
645
- /* */
646
- /* */
647
- /* */
648
- /* */
649
- /* */
650
- /* */
651
- /* */
652
- /* */
653
- /* */
654
- /* */
655
- /* */
656
- /* */
657
- /* */
658
- /* */
659
- /* */
660
- /* */
661
- /* */
662
- /* */
663
- /* */
664
- /* */
665
- /* */
666
- /* */
667
- /* */
668
- /* */
669
- /* */
670
- /* */
671
- /* */
672
- /* */
673
- /* */
674
- /* */
675
- /* */
676
- /* */
677
- /* */
678
- /* */
679
- /* */
680
- /* */
681
- /* */
682
- async isElevated() {
683
- /* */
684
- /* */
685
- /* */
686
- /* */
687
- }
688
- /* */
689
- /* */
690
- /* */
691
- /* */
692
- /* */
693
- /* */
694
- /* */
695
- /* */
696
- /* */
697
- /* */
698
- /* */
699
- /* */
700
- /* */
701
- /* */
702
- /* */
703
- /* */
704
- /* */
705
- /* */
706
- /* */
707
- /* */
708
- /* */
709
- /* */
710
- /* */
711
- /* */
712
- async mesureExectionInMs(description, functionToExecute, ...functionArguments) {
713
- var start = new Date();
714
- await Helpers.runSyncOrAsync(functionToExecute, ...functionArguments);
715
- //@ts-ignore
716
- var end = new Date() - start;
717
- if (Morphi.IsBrowser) {
718
- Helpers.info(`Execution time: ${end.toString()}ms for "${description}"`);
719
- }
720
- /* */
721
- /* */
722
- return end;
723
- }
724
- mesureExectionInMsSync(description, functionToExecute) {
725
- var start = new Date();
726
- functionToExecute();
727
- //@ts-ignore
728
- var end = new Date() - start;
729
- if (Morphi.IsBrowser) {
730
- Helpers.log(`Execution time: ${end.toString()}ms for "${description}"`);
731
- }
732
- /* */
733
- /* */
734
- return end;
735
- }
736
- waitForCondition(conditionFn, howOfftenCheckInMs = 1000) {
737
- return new Promise(async (resolve, reject) => {
738
- const result = await Helpers.runSyncOrAsync(conditionFn);
739
- if (result) {
740
- resolve(void 0);
741
- }
742
- else {
743
- setTimeout(() => {
744
- Helpers.waitForCondition(conditionFn, howOfftenCheckInMs).then(() => {
745
- resolve(void 0);
746
- });
747
- }, howOfftenCheckInMs);
748
- }
749
- });
750
- }
751
- getBrowserVerPath(moduleName, websql = false) {
752
- /* */
753
- /* */
754
- /* */
755
- /* */
756
- /* */
757
- }
758
- getMethodName(obj, method) {
759
- var methodName = null;
760
- Object.getOwnPropertyNames(obj).forEach(prop => {
761
- if (obj[prop] === method) {
762
- methodName = prop;
763
- }
764
- });
765
- if (methodName !== null) {
766
- return methodName;
767
- }
768
- var proto = Object.getPrototypeOf(obj);
769
- if (proto) {
770
- return Helpers.getMethodName(proto, method);
771
- }
772
- return null;
773
- }
774
- fixWebpackEnv(env) {
775
- _.forIn(env, (v, k) => {
776
- const value = v;
777
- if (value === 'true')
778
- env[k] = true;
779
- if (value === 'false')
780
- env[k] = false;
781
- });
782
- }
783
- }
784
- applyMixins(HelpersTnp, [
785
- HelpersStringsRegexes,
786
- HelpersEnvironment,
787
- /* */
788
- /* */
789
- /* */
790
- ]);
791
- ;
525
+ const componentContextSymbol = Symbol();
526
+ const componentsDestroy$Subjects = {};
527
+ class SerializedSubject {
528
+ constructor(id) {
529
+ this.id = id;
530
+ }
531
+ }
532
+ var NgHelpers;
533
+ (function (NgHelpers) {
534
+ function subjectId(destroySubject) {
535
+ const id = Math.random().toString(36).substring(2);
536
+ if (!destroySubject[componentContextSymbol]) {
537
+ destroySubject[componentContextSymbol] = new SerializedSubject(id);
538
+ componentsDestroy$Subjects[id] = destroySubject;
539
+ }
540
+ return destroySubject[componentContextSymbol];
541
+ }
542
+ /**
543
+ * if you are using this.. please call Helpers.ng.unsubscribe(this.$destroy) in ngOnDestroy();
544
+ */
545
+ function serialize(destroy$) {
546
+ return subjectId(destroy$);
547
+ }
548
+ NgHelpers.serialize = serialize;
549
+ /**
550
+ * if you are using this.. please call Helpers.ng.unsubscribe(this.$destroy) in ngOnDestroy();
551
+ */
552
+ function deserialize(destroy$) {
553
+ if (destroy$?.id) {
554
+ const realDestroySubject = componentsDestroy$Subjects[destroy$.id];
555
+ return realDestroySubject;
556
+ }
557
+ return new Subject();
558
+ }
559
+ NgHelpers.deserialize = deserialize;
560
+ function unsubscribe(destroy$) {
561
+ const destroySubject = subjectId(destroy$);
562
+ if (destroySubject?.id) {
563
+ delete componentsDestroy$Subjects[destroySubject.id];
564
+ delete destroySubject[componentContextSymbol];
565
+ }
566
+ }
567
+ NgHelpers.unsubscribe = unsubscribe;
568
+ /**
569
+ get properties from scss file
570
+
571
+
572
+ import styles from './tasks-ngrx-data.component.scss';
573
+
574
+ export class ExampleComponent {
575
+ sassFile = sassFile(styles);
576
+
577
+ async ngOnInit() {
578
+ this.tasksService.getAll();
579
+ console.log(this.sassFile.stringValue('--max-container-size'))
580
+ console.log(this.sassFile.numberValue('--max-container-size'))
581
+ }
582
+ }
583
+ */
584
+ function sassFile(styles) {
585
+ const lines = (styles.split('\n'));
586
+ return {
587
+ stringValue: (name) => {
588
+ for (let index = 0; index < lines.length; index++) {
589
+ const l = lines[index];
590
+ const [varName, value] = l.trim().split(':');
591
+ if (varName === name) {
592
+ return value.replace(';', '');
593
+ }
594
+ }
595
+ },
596
+ numberValue: (name) => {
597
+ for (let index = 0; index < lines.length; index++) {
598
+ const l = lines[index];
599
+ const [varName, value] = l.trim().split(':');
600
+ if (varName === name) {
601
+ return Number(value.replace('px', '').replace(';', ''));
602
+ }
603
+ }
604
+ }
605
+ };
606
+ }
607
+ NgHelpers.sassFile = sassFile;
608
+ })(NgHelpers || (NgHelpers = {}));
609
+ ;
610
+ ({}); // @--end-of-file-for-module=tnp-helpers lib/angular.helper.ts
611
+
612
+ function applyMixins(derivedCtor, baseCtors) {
613
+ baseCtors.forEach(baseCtor => {
614
+ Object.getOwnPropertyNames(baseCtor.prototype).forEach(name => {
615
+ Object.defineProperty(derivedCtor.prototype, name, Object.getOwnPropertyDescriptor(baseCtor.prototype, name));
616
+ });
617
+ });
618
+ }
619
+ // @ts-ignore
620
+ class HelpersTnp extends CoreHelpers {
621
+ constructor(
622
+ /* */
623
+ /* */
624
+ /* */
625
+ /* */
626
+ /* */
627
+ /* */
628
+ /* */
629
+ /* */
630
+ /* */
631
+ /* */
632
+ /* */
633
+ /* */
634
+ /* */
635
+ arrays = new HelpersArrayObj(), strings = new HelpersStrings(), numbers = new HelpersNumber(), browser = HelpersBrowaser.instance, ng = NgHelpers) {
636
+ super();
637
+ this.arrays = arrays;
638
+ this.strings = strings;
639
+ this.numbers = numbers;
640
+ this.browser = browser;
641
+ this.ng = ng;
642
+ this.conditionWait = conditionWait;
643
+ /* */
644
+ /* */
645
+ /* */
646
+ /* */
647
+ /* */
648
+ /* */
649
+ /* */
650
+ /* */
651
+ /* */
652
+ /* */
653
+ /* */
654
+ /* */
655
+ /* */
656
+ /* */
657
+ /* */
658
+ /* */
659
+ /* */
660
+ /* */
661
+ /* */
662
+ /* */
663
+ /* */
664
+ /* */
665
+ /* */
666
+ /* */
667
+ /* */
668
+ /* */
669
+ /* */
670
+ /* */
671
+ /* */
672
+ /* */
673
+ /* */
674
+ /* */
675
+ /* */
676
+ /* */
677
+ /* */
678
+ /* */
679
+ /* */
680
+ /* */
681
+ /* */
682
+ /* */
683
+ /* */
684
+ /* */
685
+ /* */
686
+ /* */
687
+ /* */
688
+ /* */
689
+ /* */
690
+ /* */
691
+ /* */
692
+ /* */
693
+ /* */
694
+ /* */
695
+ /* */
696
+ /* */
697
+ /* */
698
+ /* */
699
+ /* */
700
+ /* */
701
+ /* */
702
+ /* */
703
+ /* */
704
+ /* */
705
+ /* */
706
+ /* */
707
+ /* */
708
+ /* */
709
+ /* */
710
+ /* */
711
+ /* */
712
+ /* */
713
+ /* */
714
+ /* */
715
+ /* */
716
+ /* */
717
+ /* */
718
+ /* */
719
+ /* */
720
+ /* */
721
+ this.applyMixins = applyMixins;
722
+ }
723
+ static get Instance() {
724
+ if (!HelpersTnp._instance) {
725
+ HelpersTnp._instance = new HelpersTnp();
726
+ }
727
+ return HelpersTnp._instance;
728
+ }
729
+ CLIWRAP(f, name) {
730
+ CLASS.setName(f, name);
731
+ return f;
732
+ }
733
+ /* */
734
+ /* */
735
+ /* */
736
+ /* */
737
+ /* */
738
+ /* */
739
+ /* */
740
+ /* */
741
+ /* */
742
+ /* */
743
+ /* */
744
+ /* */
745
+ /* */
746
+ /* */
747
+ /* */
748
+ /* */
749
+ /* */
750
+ /* */
751
+ /* */
752
+ /* */
753
+ /* */
754
+ /* */
755
+ /* */
756
+ /* */
757
+ /* */
758
+ /* */
759
+ /* */
760
+ /* */
761
+ /* */
762
+ /* */
763
+ /* */
764
+ /* */
765
+ /* */
766
+ /* */
767
+ /* */
768
+ /* */
769
+ /* */
770
+ /* */
771
+ async isElevated() {
772
+ /* */
773
+ /* */
774
+ /* */
775
+ /* */
776
+ }
777
+ /* */
778
+ /* */
779
+ /* */
780
+ /* */
781
+ /* */
782
+ /* */
783
+ /* */
784
+ /* */
785
+ /* */
786
+ /* */
787
+ /* */
788
+ /* */
789
+ /* */
790
+ /* */
791
+ /* */
792
+ /* */
793
+ /* */
794
+ /* */
795
+ /* */
796
+ /* */
797
+ /* */
798
+ /* */
799
+ /* */
800
+ /* */
801
+ async mesureExectionInMs(description, functionToExecute, ...functionArguments) {
802
+ var start = new Date();
803
+ await Helpers.runSyncOrAsync(functionToExecute, ...functionArguments);
804
+ //@ts-ignore
805
+ var end = new Date() - start;
806
+ if (Morphi.IsBrowser) {
807
+ Helpers.info(`Execution time: ${end.toString()}ms for "${description}"`);
808
+ }
809
+ /* */
810
+ /* */
811
+ return end;
812
+ }
813
+ mesureExectionInMsSync(description, functionToExecute) {
814
+ var start = new Date();
815
+ functionToExecute();
816
+ //@ts-ignore
817
+ var end = new Date() - start;
818
+ if (Morphi.IsBrowser) {
819
+ Helpers.log(`Execution time: ${end.toString()}ms for "${description}"`);
820
+ }
821
+ /* */
822
+ /* */
823
+ return end;
824
+ }
825
+ waitForCondition(conditionFn, howOfftenCheckInMs = 1000) {
826
+ return new Promise(async (resolve, reject) => {
827
+ const result = await Helpers.runSyncOrAsync(conditionFn);
828
+ if (result) {
829
+ resolve(void 0);
830
+ }
831
+ else {
832
+ setTimeout(() => {
833
+ Helpers.waitForCondition(conditionFn, howOfftenCheckInMs).then(() => {
834
+ resolve(void 0);
835
+ });
836
+ }, howOfftenCheckInMs);
837
+ }
838
+ });
839
+ }
840
+ getBrowserVerPath(moduleName, websql = false) {
841
+ /* */
842
+ /* */
843
+ /* */
844
+ /* */
845
+ /* */
846
+ }
847
+ getMethodName(obj, method) {
848
+ var methodName = null;
849
+ Object.getOwnPropertyNames(obj).forEach(prop => {
850
+ if (obj[prop] === method) {
851
+ methodName = prop;
852
+ }
853
+ });
854
+ if (methodName !== null) {
855
+ return methodName;
856
+ }
857
+ var proto = Object.getPrototypeOf(obj);
858
+ if (proto) {
859
+ return Helpers.getMethodName(proto, method);
860
+ }
861
+ return null;
862
+ }
863
+ fixWebpackEnv(env) {
864
+ _.forIn(env, (v, k) => {
865
+ const value = v;
866
+ if (value === 'true')
867
+ env[k] = true;
868
+ if (value === 'false')
869
+ env[k] = false;
870
+ });
871
+ }
872
+ }
873
+ applyMixins(HelpersTnp, [
874
+ HelpersStringsRegexes,
875
+ HelpersEnvironment,
876
+ /* */
877
+ /* */
878
+ /* */
879
+ ]);
880
+ ;
792
881
  ({}); // @--end-of-file-for-module=tnp-helpers lib/helpers.ts
793
882
 
794
- const BaselineSiteJoinprefix = '__';
795
- const PREFIXES = {
796
- BASELINE: BaselineSiteJoinprefix,
797
- DELETED: '____DELETED____',
798
- ORIGINAL: '____ORIGINAL____',
799
- };
883
+ const BaselineSiteJoinprefix = '__';
884
+ const PREFIXES = {
885
+ BASELINE: BaselineSiteJoinprefix,
886
+ DELETED: '____DELETED____',
887
+ ORIGINAL: '____ORIGINAL____',
888
+ };
800
889
  ({}); // @--end-of-file-for-module=tnp-helpers lib/constants.ts
801
890
 
802
- /* */
803
- const Helpers$1 = HelpersTnp.Instance;
804
- class Project {
805
- constructor() {
806
- /* */
807
- /* */
808
- this.cache = {};
809
- this.browser = {};
810
- }
811
- static typeFrom(location) {
812
- /* */
813
- /* */
814
- /* */
815
- /* */
816
- /* */
817
- /* */
818
- /* */
819
- /* */
820
- /* */
821
- /* */
822
- /* */
823
- /* */
824
- return (void 0);
825
- }
826
- static unload(project) {
827
- Project.projects = Project.projects.filter(f => f !== project);
828
- }
829
- static From(locationOfProj) {
830
- /* */
831
- /* */
832
- /* */
833
- /* */
834
- /* */
835
- /* */
836
- /* */
837
- /* */
838
- /* */
839
- /* */
840
- /* */
841
- /* */
842
- /* */
843
- /* */
844
- /* */
845
- /* */
846
- /* */
847
- /* */
848
- /* */
849
- /* */
850
- /* */
851
- /* */
852
- /* */
853
- /* */
854
- /* */
855
- /* */
856
- /* */
857
- /* */
858
- /* */
859
- /* */
860
- /* */
861
- /* */
862
- /* */
863
- /* */
864
- /* */
865
- /* */
866
- /* */
867
- /* */
868
- /* */
869
- /* */
870
- /* */
871
- /* */
872
- /* */
873
- /* */
874
- /* */
875
- /* */
876
- /* */
877
- /* */
878
- /* */
879
- /* */
880
- /* */
881
- /* */
882
- /* */
883
- /* */
884
- /* */
885
- /* */
886
- /* */
887
- /* */
888
- /* */
889
- /* */
890
- /* */
891
- /* */
892
- /* */
893
- /* */
894
- /* */
895
- /* */
896
- /* */
897
- /* */
898
- /* */
899
- /* */
900
- /* */
901
- /* */
902
- /* */
903
- /* */
904
- /* */
905
- /* */
906
- /* */
907
- /* */
908
- /* */
909
- /* */
910
- /* */
911
- /* */
912
- /* */
913
- /* */
914
- /* */
915
- /* */
916
- /* */
917
- /* */
918
- /* */
919
- /* */
920
- /* */
921
- /* */
922
- /* */
923
- /* */
924
- /* */
925
- /* */
926
- /* */
927
- /* */
928
- /* */
929
- /* */
930
- /* */
931
- /* */
932
- /* */
933
- /* */
934
- /* */
935
- /* */
936
- /* */
937
- /* */
938
- /* */
939
- /* */
940
- /* */
941
- /* */
942
- /* */
943
- /* */
944
- /* */
945
- /* */
946
- /* */
947
- return (void 0);
948
- }
949
- static nearestTo(absoluteLocation, options) {
950
- /* */
951
- /* */
952
- /* */
953
- /* */
954
- /* */
955
- /* */
956
- /* */
957
- /* */
958
- /* */
959
- /* */
960
- /* */
961
- /* */
962
- /* */
963
- /* */
964
- /* */
965
- /* */
966
- /* */
967
- /* */
968
- /* */
969
- /* */
970
- /* */
971
- /* */
972
- /* */
973
- /* */
974
- /* */
975
- /* */
976
- /* */
977
- /* */
978
- /* */
979
- /* */
980
- /* */
981
- /* */
982
- /* */
983
- /* */
984
- /* */
985
- /* */
986
- /* */
987
- /* */
988
- /* */
989
- /* */
990
- /* */
991
- /* */
992
- /* */
993
- /* */
994
- /* */
995
- /* */
996
- /* */
997
- /* */
998
- /* */
999
- /* */
1000
- /* */
1001
- /* */
1002
- /* */
1003
- /* */
1004
- /* */
1005
- /* */
1006
- /* */
1007
- /* */
1008
- return (void 0);
1009
- }
1010
- static allProjectFrom(absoluteLocation, stopOnCwd = '/') {
1011
- /* */
1012
- /* */
1013
- /* */
1014
- /* */
1015
- /* */
1016
- /* */
1017
- /* */
1018
- /* */
1019
- /* */
1020
- /* */
1021
- /* */
1022
- /* */
1023
- /* */
1024
- /* */
1025
- /* */
1026
- /* */
1027
- /* */
1028
- /* */
1029
- /* */
1030
- /* */
1031
- /* */
1032
- /* */
1033
- return (void 0);
1034
- }
1035
- static DefaultPortByType(type) {
1036
- if (type === 'workspace') {
1037
- return 5000;
1038
- }
1039
- if (type === 'angular-client') {
1040
- return 4300;
1041
- }
1042
- if (type === 'angular-lib') {
1043
- return 4250;
1044
- }
1045
- if (type === 'electron-client') {
1046
- return 4350;
1047
- }
1048
- if (type === 'ionic-client') {
1049
- return 8080;
1050
- }
1051
- if (type === 'docker') {
1052
- return 5000;
1053
- }
1054
- if (type === 'isomorphic-lib') {
1055
- return 4000;
1056
- }
1057
- if (type === 'container' || type === 'unknow-npm-project') {
1058
- return;
1059
- }
1060
- }
1061
- static get isBundleMode() {
1062
- if (Helpers$1.isBrowser) {
1063
- return true;
1064
- }
1065
- /* */
1066
- /* */
1067
- }
1068
- static get Current() {
1069
- /* */
1070
- /* */
1071
- /* */
1072
- /* */
1073
- /* */
1074
- /* */
1075
- /* */
1076
- /* */
1077
- /* */
1078
- /* */
1079
- /* */
1080
- return (void 0);
1081
- }
1082
- /**
1083
- * @deprecated
1084
- */
1085
- static get Tnp() {
1086
- /* */
1087
- /* */
1088
- /* */
1089
- /* */
1090
- /* */
1091
- /* */
1092
- /* */
1093
- return (void 0);
1094
- }
1095
- static by(libraryType, version
1096
- /* */
1097
- /* */
1098
- ) {
1099
- /* */
1100
- /* */
1101
- /* */
1102
- /* */
1103
- /* */
1104
- /* */
1105
- /* */
1106
- /* */
1107
- /* */
1108
- /* */
1109
- /* */
1110
- /* */
1111
- /* */
1112
- /* */
1113
- /* */
1114
- /* */
1115
- /* */
1116
- /* */
1117
- /* */
1118
- /* */
1119
- /* */
1120
- /* */
1121
- /* */
1122
- /* */
1123
- /* */
1124
- /* */
1125
- /* */
1126
- return (void 0);
1127
- }
1128
- defineProperty(variableName, classFn) {
1129
- /* */
1130
- /* */
1131
- /* */
1132
- /* */
1133
- /* */
1134
- /* */
1135
- /* */
1136
- /* */
1137
- /* */
1138
- /* */
1139
- /* */
1140
- /* */
1141
- /* */
1142
- /* */
1143
- /* */
1144
- /* */
1145
- /* */
1146
- /* */
1147
- /* */
1148
- /* */
1149
- /* */
1150
- /* */
1151
- /* */
1152
- /* */
1153
- return (void 0);
1154
- }
1155
- setType(type) {
1156
- // @ts-ignore
1157
- this._type = type;
1158
- }
1159
- typeIs(...types) {
1160
- return this._type && types.includes(this._type);
1161
- }
1162
- typeIsNot(...types) {
1163
- return !this.typeIs(...types);
1164
- }
1165
- forEmptyStructure() {
1166
- /* */
1167
- /* */
1168
- /* */
1169
- /* */
1170
- /* */
1171
- return (void 0);
1172
- }
1173
- }
1174
- Project.projects = [];
1175
- /**
1176
- * To speed up checking folder I am keeping pathes for alterdy checked folder
1177
- * This may break things that are creating new projects
1178
- */
1179
- Project.emptyLocations = [];
1180
- /* */
1181
- /* */
1182
- /* */
1183
- /* */
1184
- /* */
1185
- /* */
1186
- /* */
1187
- /* */
1188
- /* */
1189
- /* */
1190
- /* */
1191
- /* */
1192
- /* */
1193
- /* */
1194
- /* */
1195
- /* */
1196
- /* */
1197
- /* */
1198
- /* */
1199
- /* */
1200
- /* */
1201
- /* */
1202
- /* */
1203
- /* */
1204
- /* */
1205
- /* */
1206
- /* */
1207
- /* */
1208
- /* */
1209
- /* */
1210
- /* */
1211
- /* */
1212
- /* */
1213
- /* */
1214
- /* */
1215
- /* */
1216
- /* */
1217
- /* */
1218
- /* */
1219
- /* */
1220
- /* */
1221
- /* */
1222
- /* */
1223
- /* */
1224
- ;
891
+ /* */
892
+ const Helpers$1 = HelpersTnp.Instance;
893
+ class Project {
894
+ constructor() {
895
+ /* */
896
+ /* */
897
+ this.cache = {};
898
+ this.browser = {};
899
+ }
900
+ static typeFrom(location) {
901
+ /* */
902
+ /* */
903
+ /* */
904
+ /* */
905
+ /* */
906
+ /* */
907
+ /* */
908
+ /* */
909
+ /* */
910
+ /* */
911
+ /* */
912
+ /* */
913
+ return (void 0);
914
+ }
915
+ static unload(project) {
916
+ Project.projects = Project.projects.filter(f => f !== project);
917
+ }
918
+ static From(locationOfProj) {
919
+ /* */
920
+ /* */
921
+ /* */
922
+ /* */
923
+ /* */
924
+ /* */
925
+ /* */
926
+ /* */
927
+ /* */
928
+ /* */
929
+ /* */
930
+ /* */
931
+ /* */
932
+ /* */
933
+ /* */
934
+ /* */
935
+ /* */
936
+ /* */
937
+ /* */
938
+ /* */
939
+ /* */
940
+ /* */
941
+ /* */
942
+ /* */
943
+ /* */
944
+ /* */
945
+ /* */
946
+ /* */
947
+ /* */
948
+ /* */
949
+ /* */
950
+ /* */
951
+ /* */
952
+ /* */
953
+ /* */
954
+ /* */
955
+ /* */
956
+ /* */
957
+ /* */
958
+ /* */
959
+ /* */
960
+ /* */
961
+ /* */
962
+ /* */
963
+ /* */
964
+ /* */
965
+ /* */
966
+ /* */
967
+ /* */
968
+ /* */
969
+ /* */
970
+ /* */
971
+ /* */
972
+ /* */
973
+ /* */
974
+ /* */
975
+ /* */
976
+ /* */
977
+ /* */
978
+ /* */
979
+ /* */
980
+ /* */
981
+ /* */
982
+ /* */
983
+ /* */
984
+ /* */
985
+ /* */
986
+ /* */
987
+ /* */
988
+ /* */
989
+ /* */
990
+ /* */
991
+ /* */
992
+ /* */
993
+ /* */
994
+ /* */
995
+ /* */
996
+ /* */
997
+ /* */
998
+ /* */
999
+ /* */
1000
+ /* */
1001
+ /* */
1002
+ /* */
1003
+ /* */
1004
+ /* */
1005
+ /* */
1006
+ /* */
1007
+ /* */
1008
+ /* */
1009
+ /* */
1010
+ /* */
1011
+ /* */
1012
+ /* */
1013
+ /* */
1014
+ /* */
1015
+ /* */
1016
+ /* */
1017
+ /* */
1018
+ /* */
1019
+ /* */
1020
+ /* */
1021
+ /* */
1022
+ /* */
1023
+ /* */
1024
+ /* */
1025
+ /* */
1026
+ /* */
1027
+ /* */
1028
+ /* */
1029
+ /* */
1030
+ /* */
1031
+ /* */
1032
+ /* */
1033
+ /* */
1034
+ /* */
1035
+ /* */
1036
+ return (void 0);
1037
+ }
1038
+ static nearestTo(absoluteLocation, options) {
1039
+ /* */
1040
+ /* */
1041
+ /* */
1042
+ /* */
1043
+ /* */
1044
+ /* */
1045
+ /* */
1046
+ /* */
1047
+ /* */
1048
+ /* */
1049
+ /* */
1050
+ /* */
1051
+ /* */
1052
+ /* */
1053
+ /* */
1054
+ /* */
1055
+ /* */
1056
+ /* */
1057
+ /* */
1058
+ /* */
1059
+ /* */
1060
+ /* */
1061
+ /* */
1062
+ /* */
1063
+ /* */
1064
+ /* */
1065
+ /* */
1066
+ /* */
1067
+ /* */
1068
+ /* */
1069
+ /* */
1070
+ /* */
1071
+ /* */
1072
+ /* */
1073
+ /* */
1074
+ /* */
1075
+ /* */
1076
+ /* */
1077
+ /* */
1078
+ /* */
1079
+ /* */
1080
+ /* */
1081
+ /* */
1082
+ /* */
1083
+ /* */
1084
+ /* */
1085
+ /* */
1086
+ /* */
1087
+ /* */
1088
+ /* */
1089
+ /* */
1090
+ /* */
1091
+ /* */
1092
+ /* */
1093
+ /* */
1094
+ /* */
1095
+ /* */
1096
+ /* */
1097
+ return (void 0);
1098
+ }
1099
+ static allProjectFrom(absoluteLocation, stopOnCwd = '/') {
1100
+ /* */
1101
+ /* */
1102
+ /* */
1103
+ /* */
1104
+ /* */
1105
+ /* */
1106
+ /* */
1107
+ /* */
1108
+ /* */
1109
+ /* */
1110
+ /* */
1111
+ /* */
1112
+ /* */
1113
+ /* */
1114
+ /* */
1115
+ /* */
1116
+ /* */
1117
+ /* */
1118
+ /* */
1119
+ /* */
1120
+ /* */
1121
+ /* */
1122
+ return (void 0);
1123
+ }
1124
+ static DefaultPortByType(type) {
1125
+ if (type === 'workspace') {
1126
+ return 5000;
1127
+ }
1128
+ if (type === 'angular-client') {
1129
+ return 4300;
1130
+ }
1131
+ if (type === 'angular-lib') {
1132
+ return 4250;
1133
+ }
1134
+ if (type === 'electron-client') {
1135
+ return 4350;
1136
+ }
1137
+ if (type === 'ionic-client') {
1138
+ return 8080;
1139
+ }
1140
+ if (type === 'docker') {
1141
+ return 5000;
1142
+ }
1143
+ if (type === 'isomorphic-lib') {
1144
+ return 4000;
1145
+ }
1146
+ if (type === 'container' || type === 'unknow-npm-project') {
1147
+ return;
1148
+ }
1149
+ }
1150
+ static get isBundleMode() {
1151
+ if (Helpers$1.isBrowser) {
1152
+ return true;
1153
+ }
1154
+ /* */
1155
+ /* */
1156
+ }
1157
+ static get Current() {
1158
+ /* */
1159
+ /* */
1160
+ /* */
1161
+ /* */
1162
+ /* */
1163
+ /* */
1164
+ /* */
1165
+ /* */
1166
+ /* */
1167
+ /* */
1168
+ /* */
1169
+ return (void 0);
1170
+ }
1171
+ /**
1172
+ * @deprecated
1173
+ */
1174
+ static get Tnp() {
1175
+ /* */
1176
+ /* */
1177
+ /* */
1178
+ /* */
1179
+ /* */
1180
+ /* */
1181
+ /* */
1182
+ return (void 0);
1183
+ }
1184
+ static by(libraryType, version
1185
+ /* */
1186
+ /* */
1187
+ ) {
1188
+ /* */
1189
+ /* */
1190
+ /* */
1191
+ /* */
1192
+ /* */
1193
+ /* */
1194
+ /* */
1195
+ /* */
1196
+ /* */
1197
+ /* */
1198
+ /* */
1199
+ /* */
1200
+ /* */
1201
+ /* */
1202
+ /* */
1203
+ /* */
1204
+ /* */
1205
+ /* */
1206
+ /* */
1207
+ /* */
1208
+ /* */
1209
+ /* */
1210
+ /* */
1211
+ /* */
1212
+ /* */
1213
+ /* */
1214
+ /* */
1215
+ return (void 0);
1216
+ }
1217
+ defineProperty(variableName, classFn) {
1218
+ /* */
1219
+ /* */
1220
+ /* */
1221
+ /* */
1222
+ /* */
1223
+ /* */
1224
+ /* */
1225
+ /* */
1226
+ /* */
1227
+ /* */
1228
+ /* */
1229
+ /* */
1230
+ /* */
1231
+ /* */
1232
+ /* */
1233
+ /* */
1234
+ /* */
1235
+ /* */
1236
+ /* */
1237
+ /* */
1238
+ /* */
1239
+ /* */
1240
+ /* */
1241
+ /* */
1242
+ return (void 0);
1243
+ }
1244
+ setType(type) {
1245
+ // @ts-ignore
1246
+ this._type = type;
1247
+ }
1248
+ typeIs(...types) {
1249
+ return this._type && types.includes(this._type);
1250
+ }
1251
+ typeIsNot(...types) {
1252
+ return !this.typeIs(...types);
1253
+ }
1254
+ forEmptyStructure() {
1255
+ /* */
1256
+ /* */
1257
+ /* */
1258
+ /* */
1259
+ /* */
1260
+ return (void 0);
1261
+ }
1262
+ }
1263
+ Project.projects = [];
1264
+ /**
1265
+ * To speed up checking folder I am keeping pathes for alterdy checked folder
1266
+ * This may break things that are creating new projects
1267
+ */
1268
+ Project.emptyLocations = [];
1269
+ /* */
1270
+ /* */
1271
+ /* */
1272
+ /* */
1273
+ /* */
1274
+ /* */
1275
+ /* */
1276
+ /* */
1277
+ /* */
1278
+ /* */
1279
+ /* */
1280
+ /* */
1281
+ /* */
1282
+ /* */
1283
+ /* */
1284
+ /* */
1285
+ /* */
1286
+ /* */
1287
+ /* */
1288
+ /* */
1289
+ /* */
1290
+ /* */
1291
+ /* */
1292
+ /* */
1293
+ /* */
1294
+ /* */
1295
+ /* */
1296
+ /* */
1297
+ /* */
1298
+ /* */
1299
+ /* */
1300
+ /* */
1301
+ /* */
1302
+ /* */
1303
+ /* */
1304
+ /* */
1305
+ /* */
1306
+ /* */
1307
+ /* */
1308
+ /* */
1309
+ /* */
1310
+ /* */
1311
+ /* */
1312
+ /* */
1313
+ ;
1225
1314
  ({}); // @--end-of-file-for-module=tnp-helpers lib/project.ts
1226
1315
 
1227
- ;
1316
+ ;
1228
1317
  ({}); // @--end-of-file-for-module=tnp-helpers lib/firedev-models.ts
1229
1318
 
1230
- class BaseComponent {
1231
- constructor() {
1232
- // @ts-ignore
1233
- this.model = {};
1234
- this.handlers = [];
1235
- }
1236
- ngOnDestroy() {
1237
- this.handlers.forEach(h => h.unsubscribe());
1238
- this.handlers.length = 0;
1239
- }
1240
- }
1241
- BaseComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: BaseComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
1242
- BaseComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.12", type: BaseComponent, selector: "app-base-component-meta", inputs: { model: "model" }, ngImport: i0, template: '<div></div>', isInline: true });
1243
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: BaseComponent, decorators: [{
1244
- type: Component,
1245
- args: [{
1246
- selector: 'app-base-component-meta',
1247
- template: '<div></div>'
1248
- }]
1249
- }], propDecorators: { model: [{
1250
- type: Input
1251
- }] } });
1252
- const isCalledNgInitAfterInternalRefresh = Symbol();
1253
- class BaseComponentForRouter extends BaseComponent {
1254
- constructor(__router) {
1255
- super();
1256
- this.__router = __router;
1257
- this[isCalledNgInitAfterInternalRefresh] = false;
1258
- }
1259
- isCalledNgInitAfterInternalRefresh() {
1260
- return !!this[isCalledNgInitAfterInternalRefresh];
1261
- }
1262
- reloadNgOninitOnUrlChange() {
1263
- this.handlers.push(this.__router.events.subscribe(event => {
1264
- if (event instanceof NavigationEnd && this['ngOnInit']) {
1265
- this[isCalledNgInitAfterInternalRefresh] = true;
1266
- this['ngOnInit']();
1267
- if (this[isCalledNgInitAfterInternalRefresh]) {
1268
- this[isCalledNgInitAfterInternalRefresh] = false;
1269
- }
1270
- }
1271
- }));
1272
- }
1273
- }
1274
- ;
1319
+ class BaseComponent {
1320
+ constructor() {
1321
+ // @ts-ignore
1322
+ this.model = {};
1323
+ this.handlers = [];
1324
+ }
1325
+ ngOnDestroy() {
1326
+ this.handlers.forEach(h => h.unsubscribe());
1327
+ this.handlers.length = 0;
1328
+ }
1329
+ }
1330
+ BaseComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: BaseComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
1331
+ BaseComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.12", type: BaseComponent, selector: "app-base-component-meta", inputs: { model: "model" }, ngImport: i0, template: '<div></div>', isInline: true });
1332
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: BaseComponent, decorators: [{
1333
+ type: Component,
1334
+ args: [{
1335
+ selector: 'app-base-component-meta',
1336
+ template: '<div></div>'
1337
+ }]
1338
+ }], propDecorators: { model: [{
1339
+ type: Input
1340
+ }] } });
1341
+ const isCalledNgInitAfterInternalRefresh = Symbol();
1342
+ class BaseComponentForRouter extends BaseComponent {
1343
+ constructor(__router) {
1344
+ super();
1345
+ this.__router = __router;
1346
+ this[isCalledNgInitAfterInternalRefresh] = false;
1347
+ }
1348
+ isCalledNgInitAfterInternalRefresh() {
1349
+ return !!this[isCalledNgInitAfterInternalRefresh];
1350
+ }
1351
+ reloadNgOninitOnUrlChange() {
1352
+ this.handlers.push(this.__router.events.subscribe(event => {
1353
+ if (event instanceof NavigationEnd && this['ngOnInit']) {
1354
+ this[isCalledNgInitAfterInternalRefresh] = true;
1355
+ this['ngOnInit']();
1356
+ if (this[isCalledNgInitAfterInternalRefresh]) {
1357
+ this[isCalledNgInitAfterInternalRefresh] = false;
1358
+ }
1359
+ }
1360
+ }));
1361
+ }
1362
+ }
1363
+ ;
1275
1364
  ({}); // @--end-of-file-for-module=tnp-helpers lib/base-component.ts
1276
1365
 
1277
- const log$2 = Log.create(`DualComponentController`);
1278
- class DualComponentController {
1279
- constructor(cmp, isFormlyMode = false) {
1280
- this.cmp = cmp;
1281
- this.isFormlyMode = isFormlyMode;
1282
- }
1283
- getValTemplateOptions(propertyName) {
1284
- if (this.isFormlyMode) {
1285
- const res = this.cmp.field?.templateOptions[propertyName];
1286
- if (res === void 0 && this.cmp[propertyName]) {
1287
- return this.cmp[propertyName];
1288
- }
1289
- return res;
1290
- }
1291
- return this.cmp[propertyName];
1292
- }
1293
- getValContext(propertyName) {
1294
- if (this.isFormlyMode) {
1295
- const res = this.cmp?.field[propertyName];
1296
- if (res === void 0 && this.cmp[propertyName]) {
1297
- return this.cmp[propertyName];
1298
- }
1299
- return res;
1300
- }
1301
- return this.cmp[propertyName];
1302
- }
1303
- get disabled() {
1304
- return this.getValTemplateOptions('disabled');
1305
- }
1306
- get required() {
1307
- return this.getValTemplateOptions('required');
1308
- }
1309
- get type() {
1310
- if (!this.isFormlyMode) {
1311
- return CLASS.getNameFromObject(this.cmp);
1312
- }
1313
- return this.getValContext('type');
1314
- }
1315
- get label() {
1316
- return this.getValTemplateOptions('label');
1317
- }
1318
- get placeholder() {
1319
- return this.getValTemplateOptions('placeholder');
1320
- }
1321
- get defaultValue() {
1322
- return this.getValContext('defaultValue');
1323
- }
1324
- get formControl() {
1325
- return this.getValContext('formControl');
1326
- }
1327
- get key() {
1328
- return this.getValContext('key');
1329
- }
1330
- get path() {
1331
- return this.getValContext('path');
1332
- }
1333
- get model() {
1334
- if (this.isFormlyMode) {
1335
- return this.getValContext('model');
1336
- }
1337
- else {
1338
- return this.__model;
1339
- }
1340
- }
1341
- set model(v) {
1342
- if (this.isFormlyMode) {
1343
- log$2.w(`[DualComponentController] You can't set model in formly component mode`);
1344
- }
1345
- else {
1346
- this.__model = v;
1347
- }
1348
- }
1349
- get mode() {
1350
- if (this.isFormlyMode) {
1351
- return this.getValContext('mode');
1352
- }
1353
- else {
1354
- return this.__mode;
1355
- }
1356
- }
1357
- set mode(v) {
1358
- if (this.isFormlyMode) {
1359
- }
1360
- else {
1361
- this.__mode = v;
1362
- }
1363
- }
1364
- get value() {
1365
- if (this.isFormlyMode) {
1366
- return this.cmp.field.formControl.value;
1367
- }
1368
- if (_.isString(this.path)) {
1369
- return _.get(this.cmp.model, this.path);
1370
- }
1371
- return this.cmp.model;
1372
- }
1373
- set value(v) {
1374
- if (this.isFormlyMode) {
1375
- this.cmp.field.formControl.setValue(v);
1376
- // @ts-ignore
1377
- this.cmp.change.next(v);
1378
- return;
1379
- }
1380
- if (_.isString(this.path)) {
1381
- _.set(this.cmp.model, this.path, v);
1382
- }
1383
- else {
1384
- this.cmp.model = v;
1385
- }
1386
- }
1387
- }
1388
- ;
1366
+ const log$2 = Log.create(`DualComponentController`);
1367
+ class DualComponentController {
1368
+ constructor(cmp, isFormlyMode = false) {
1369
+ this.cmp = cmp;
1370
+ this.isFormlyMode = isFormlyMode;
1371
+ }
1372
+ getValTemplateOptions(propertyName) {
1373
+ if (this.isFormlyMode) {
1374
+ const res = this.cmp.field?.templateOptions[propertyName];
1375
+ if (res === void 0 && this.cmp[propertyName]) {
1376
+ return this.cmp[propertyName];
1377
+ }
1378
+ return res;
1379
+ }
1380
+ return this.cmp[propertyName];
1381
+ }
1382
+ getValContext(propertyName) {
1383
+ if (this.isFormlyMode) {
1384
+ const res = this.cmp?.field[propertyName];
1385
+ if (res === void 0 && this.cmp[propertyName]) {
1386
+ return this.cmp[propertyName];
1387
+ }
1388
+ return res;
1389
+ }
1390
+ return this.cmp[propertyName];
1391
+ }
1392
+ get disabled() {
1393
+ return this.getValTemplateOptions('disabled');
1394
+ }
1395
+ get required() {
1396
+ return this.getValTemplateOptions('required');
1397
+ }
1398
+ get type() {
1399
+ if (!this.isFormlyMode) {
1400
+ return CLASS.getNameFromObject(this.cmp);
1401
+ }
1402
+ return this.getValContext('type');
1403
+ }
1404
+ get label() {
1405
+ return this.getValTemplateOptions('label');
1406
+ }
1407
+ get placeholder() {
1408
+ return this.getValTemplateOptions('placeholder');
1409
+ }
1410
+ get defaultValue() {
1411
+ return this.getValContext('defaultValue');
1412
+ }
1413
+ get formControl() {
1414
+ return this.getValContext('formControl');
1415
+ }
1416
+ get key() {
1417
+ return this.getValContext('key');
1418
+ }
1419
+ get path() {
1420
+ return this.getValContext('path');
1421
+ }
1422
+ get model() {
1423
+ if (this.isFormlyMode) {
1424
+ return this.getValContext('model');
1425
+ }
1426
+ else {
1427
+ return this.__model;
1428
+ }
1429
+ }
1430
+ set model(v) {
1431
+ if (this.isFormlyMode) {
1432
+ log$2.w(`[DualComponentController] You can't set model in formly component mode`);
1433
+ }
1434
+ else {
1435
+ this.__model = v;
1436
+ }
1437
+ }
1438
+ get mode() {
1439
+ if (this.isFormlyMode) {
1440
+ return this.getValContext('mode');
1441
+ }
1442
+ else {
1443
+ return this.__mode;
1444
+ }
1445
+ }
1446
+ set mode(v) {
1447
+ if (this.isFormlyMode) {
1448
+ }
1449
+ else {
1450
+ this.__mode = v;
1451
+ }
1452
+ }
1453
+ get value() {
1454
+ if (this.isFormlyMode) {
1455
+ return this.cmp.field.formControl.value;
1456
+ }
1457
+ if (_.isString(this.path)) {
1458
+ return _.get(this.cmp.model, this.path);
1459
+ }
1460
+ return this.cmp.model;
1461
+ }
1462
+ set value(v) {
1463
+ if (this.isFormlyMode) {
1464
+ this.cmp.field.formControl.setValue(v);
1465
+ // @ts-ignore
1466
+ this.cmp.change.next(v);
1467
+ return;
1468
+ }
1469
+ if (_.isString(this.path)) {
1470
+ _.set(this.cmp.model, this.path, v);
1471
+ }
1472
+ else {
1473
+ this.cmp.model = v;
1474
+ }
1475
+ }
1476
+ }
1477
+ ;
1389
1478
  ({}); // @--end-of-file-for-module=tnp-helpers lib/dual-component-ctrl.ts
1390
1479
 
1391
- const log$1 = Log.create('base formly component', Level.__NOTHING);
1392
- class BaseFormlyComponent extends FieldType {
1393
- constructor() {
1394
- super(...arguments);
1395
- this.DualComponentController = DualComponentController;
1396
- this.ctrl = {};
1397
- this.change = new EventEmitter();
1398
- // @ts-ignore
1399
- this.handlers = [];
1400
- this.__field = {
1401
- templateOptions: {}
1402
- };
1403
- }
1404
- // @ts-ignore
1405
- get mode() {
1406
- return this.ctrl.mode;
1407
- }
1408
- // @ts-ignore
1409
- set mode(v) {
1410
- this.ctrl.mode = v;
1411
- }
1412
- // @ts-ignore
1413
- set model(v) {
1414
- this.ctrl.model = v;
1415
- }
1416
- get model() {
1417
- return this.ctrl.model;
1418
- }
1419
- // @ts-ignore
1420
- set key(value) {
1421
- if (this.ctrl && this.ctrl.isFormlyMode) {
1422
- return;
1423
- }
1424
- this.path = value;
1425
- }
1426
- get key() {
1427
- if (this.ctrl && this.ctrl.isFormlyMode) {
1428
- return this.field.key;
1429
- }
1430
- return this.path;
1431
- }
1432
- ngOnDestroy() {
1433
- this.handlers.forEach(h => h.unsubscribe());
1434
- this.handlers.length = 0;
1435
- }
1436
- ngAfterViewInit() {
1437
- }
1438
- ngOnInit() {
1439
- const isFormlyMode = !!this.field;
1440
- log$1.i(`isFormlyMode: ${isFormlyMode}`);
1441
- if (!isFormlyMode) {
1442
- const that = this;
1443
- Object.defineProperty(this, 'field', {
1444
- get: function () {
1445
- return that.__field;
1446
- },
1447
- set: function (v) {
1448
- that.__field = v;
1449
- }
1450
- });
1451
- }
1452
- const existed = this.ctrl;
1453
- this.ctrl = new this.DualComponentController(this, isFormlyMode);
1454
- // @ts-ignore
1455
- Object.keys(existed).forEach(key => {
1456
- this.ctrl[key] = existed[key];
1457
- });
1458
- // @ts-ignore
1459
- this.change.next(this.ctrl.value);
1460
- }
1461
- }
1462
- BaseFormlyComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: BaseFormlyComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
1463
- BaseFormlyComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.12", type: BaseFormlyComponent, selector: "app-base-formly-component-meta", inputs: { pizda: "pizda", mode: "mode", disabled: "disabled", required: "required", label: "label", placeholder: "placeholder", defaultValue: "defaultValue", model: "model", path: "path", key: "key" }, outputs: { change: "change" }, usesInheritance: true, ngImport: i0, template: `<div></div>`, isInline: true });
1464
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: BaseFormlyComponent, decorators: [{
1465
- type: Component,
1466
- args: [{
1467
- selector: 'app-base-formly-component-meta',
1468
- template: `<div></div>`
1469
- }]
1470
- }], propDecorators: { pizda: [{
1471
- type: Input
1472
- }], mode: [{
1473
- type: Input
1474
- }], disabled: [{
1475
- type: Input
1476
- }], required: [{
1477
- type: Input
1478
- }], label: [{
1479
- type: Input
1480
- }], placeholder: [{
1481
- type: Input
1482
- }], defaultValue: [{
1483
- type: Input
1484
- }], model: [{
1485
- type: Input
1486
- }], path: [{
1487
- type: Input
1488
- }], change: [{
1489
- type: Output
1490
- }], key: [{
1491
- type: Input
1492
- }] } });
1493
- ;
1480
+ const log$1 = Log.create('base formly component', Level.__NOTHING);
1481
+ class BaseFormlyComponent extends FieldType {
1482
+ constructor() {
1483
+ super(...arguments);
1484
+ this.DualComponentController = DualComponentController;
1485
+ this.ctrl = {};
1486
+ this.change = new EventEmitter();
1487
+ // @ts-ignore
1488
+ this.handlers = [];
1489
+ this.__field = {
1490
+ templateOptions: {}
1491
+ };
1492
+ }
1493
+ // @ts-ignore
1494
+ get mode() {
1495
+ return this.ctrl.mode;
1496
+ }
1497
+ // @ts-ignore
1498
+ set mode(v) {
1499
+ this.ctrl.mode = v;
1500
+ }
1501
+ // @ts-ignore
1502
+ set model(v) {
1503
+ this.ctrl.model = v;
1504
+ }
1505
+ get model() {
1506
+ return this.ctrl.model;
1507
+ }
1508
+ // @ts-ignore
1509
+ set key(value) {
1510
+ if (this.ctrl && this.ctrl.isFormlyMode) {
1511
+ return;
1512
+ }
1513
+ this.path = value;
1514
+ }
1515
+ get key() {
1516
+ if (this.ctrl && this.ctrl.isFormlyMode) {
1517
+ return this.field.key;
1518
+ }
1519
+ return this.path;
1520
+ }
1521
+ ngOnDestroy() {
1522
+ this.handlers.forEach(h => h.unsubscribe());
1523
+ this.handlers.length = 0;
1524
+ }
1525
+ ngAfterViewInit() {
1526
+ }
1527
+ ngOnInit() {
1528
+ const isFormlyMode = !!this.field;
1529
+ log$1.i(`isFormlyMode: ${isFormlyMode}`);
1530
+ if (!isFormlyMode) {
1531
+ const that = this;
1532
+ Object.defineProperty(this, 'field', {
1533
+ get: function () {
1534
+ return that.__field;
1535
+ },
1536
+ set: function (v) {
1537
+ that.__field = v;
1538
+ }
1539
+ });
1540
+ }
1541
+ const existed = this.ctrl;
1542
+ this.ctrl = new this.DualComponentController(this, isFormlyMode);
1543
+ // @ts-ignore
1544
+ Object.keys(existed).forEach(key => {
1545
+ this.ctrl[key] = existed[key];
1546
+ });
1547
+ // @ts-ignore
1548
+ this.change.next(this.ctrl.value);
1549
+ }
1550
+ }
1551
+ BaseFormlyComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: BaseFormlyComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
1552
+ BaseFormlyComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.12", type: BaseFormlyComponent, selector: "app-base-formly-component-meta", inputs: { pizda: "pizda", mode: "mode", disabled: "disabled", required: "required", label: "label", placeholder: "placeholder", defaultValue: "defaultValue", model: "model", path: "path", key: "key" }, outputs: { change: "change" }, usesInheritance: true, ngImport: i0, template: `<div></div>`, isInline: true });
1553
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: BaseFormlyComponent, decorators: [{
1554
+ type: Component,
1555
+ args: [{
1556
+ selector: 'app-base-formly-component-meta',
1557
+ template: `<div></div>`
1558
+ }]
1559
+ }], propDecorators: { pizda: [{
1560
+ type: Input
1561
+ }], mode: [{
1562
+ type: Input
1563
+ }], disabled: [{
1564
+ type: Input
1565
+ }], required: [{
1566
+ type: Input
1567
+ }], label: [{
1568
+ type: Input
1569
+ }], placeholder: [{
1570
+ type: Input
1571
+ }], defaultValue: [{
1572
+ type: Input
1573
+ }], model: [{
1574
+ type: Input
1575
+ }], path: [{
1576
+ type: Input
1577
+ }], change: [{
1578
+ type: Output
1579
+ }], key: [{
1580
+ type: Input
1581
+ }] } });
1582
+ ;
1494
1583
  ({}); // @--end-of-file-for-module=tnp-helpers lib/base-formly-component.ts
1495
1584
 
1496
- class ResizeService {
1497
- constructor() {
1498
- this.resizeDetector = elementResizeDetectorMaker({ strategy: 'scroll' });
1499
- }
1500
- addResizeEventListener(element, handler) {
1501
- this.resizeDetector.listenTo(element, handler);
1502
- }
1503
- removeResizeEventListener(element) {
1504
- this.resizeDetector.uninstall(element);
1505
- }
1506
- }
1507
- ResizeService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: ResizeService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
1508
- ResizeService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: ResizeService });
1509
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: ResizeService, decorators: [{
1510
- type: Injectable
1511
- }], ctorParameters: function () { return []; } });
1512
- ;
1585
+ class ResizeService {
1586
+ constructor() {
1587
+ this.resizeDetector = elementResizeDetectorMaker({ strategy: 'scroll' });
1588
+ }
1589
+ addResizeEventListener(element, handler) {
1590
+ this.resizeDetector.listenTo(element, handler);
1591
+ }
1592
+ removeResizeEventListener(element) {
1593
+ this.resizeDetector.uninstall(element);
1594
+ }
1595
+ }
1596
+ ResizeService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: ResizeService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
1597
+ ResizeService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: ResizeService });
1598
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: ResizeService, decorators: [{
1599
+ type: Injectable
1600
+ }], ctorParameters: function () { return []; } });
1601
+ ;
1513
1602
  ({}); // @--end-of-file-for-module=tnp-helpers lib/resize-service.ts
1514
1603
 
1515
- const log = Log.create(`[firedev-helpers] long-press`, Level.__NOTHING);
1516
- class LongPress {
1517
- constructor() {
1518
- this.pressDuration = 1000;
1519
- this.onLongPress = new EventEmitter();
1520
- this.onLongPressing = new EventEmitter();
1521
- this.onLongPressEnd = new EventEmitter();
1522
- this.mouseX = 0;
1523
- this.mouseY = 0;
1524
- this.allowTrigger = false;
1525
- this.triggerEnd = _.debounce(() => {
1526
- this.endPress();
1527
- }, 500);
1528
- }
1529
- get press() { return this.pressing; }
1530
- get longPress() { return this.longPressing; }
1531
- onMouseDown(event) {
1532
- log.d(`MOUSE DOWN `);
1533
- if (event.which !== 1)
1534
- return;
1535
- this.allowTrigger = true;
1536
- this.mouseX = event.clientX;
1537
- this.mouseY = event.clientY;
1538
- this.pressing = true;
1539
- this.longPressing = false;
1540
- this.timeout = setTimeout(() => {
1541
- if (this.allowTrigger) {
1542
- this.longPressing = true;
1543
- log.d(`long pressing start pressDuration:${this.pressDuration} `);
1544
- this.onLongPress.emit(event);
1545
- this.loop(event);
1546
- }
1547
- }, this.pressDuration);
1548
- this.loop(event);
1549
- }
1550
- onMouseMove(event) {
1551
- if (this.pressing && !this.longPressing) {
1552
- const xThres = (event.clientX - this.mouseX) > 10;
1553
- const yThres = (event.clientY - this.mouseY) > 10;
1554
- if (xThres || yThres) {
1555
- this.endPress();
1556
- }
1557
- }
1558
- }
1559
- loop(event) {
1560
- if (this.longPressing) {
1561
- this.timeout = setTimeout(() => {
1562
- log.d(`emil longpressing`);
1563
- this.triggerEnd();
1564
- this.onLongPressing.emit(event);
1565
- this.loop(event);
1566
- }, 50);
1567
- }
1568
- }
1569
- endPress(emit = true) {
1570
- this.allowTrigger = false;
1571
- clearTimeout(this.timeout);
1572
- this.longPressing = false;
1573
- this.pressing = false;
1574
- if (emit) {
1575
- log.d(`EMIT END`);
1576
- this.onLongPressEnd.emit(true);
1577
- }
1578
- else {
1579
- log.d(`NOT EMIT END`);
1580
- }
1581
- }
1582
- onMouseUp() {
1583
- this.endPress(false);
1584
- }
1585
- }
1586
- LongPress.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: LongPress, deps: [], target: i0.ɵɵFactoryTarget.Directive });
1587
- LongPress.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.12", type: LongPress, selector: "[long-press]", inputs: { pressDuration: "pressDuration" }, outputs: { onLongPress: "onLongPress", onLongPressing: "onLongPressing", onLongPressEnd: "onLongPressEnd" }, host: { listeners: { "mousedown": "onMouseDown($event)", "mousemove": "onMouseMove($event)", "mouseup": "onMouseUp()" }, properties: { "class.press": "this.press", "class.longpress": "this.longPress" } }, ngImport: i0 });
1588
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: LongPress, decorators: [{
1589
- type: Directive,
1590
- args: [{ selector: '[long-press]' }]
1591
- }], propDecorators: { pressDuration: [{
1592
- type: Input
1593
- }], onLongPress: [{
1594
- type: Output
1595
- }], onLongPressing: [{
1596
- type: Output
1597
- }], onLongPressEnd: [{
1598
- type: Output
1599
- }], press: [{
1600
- type: HostBinding,
1601
- args: ['class.press']
1602
- }], longPress: [{
1603
- type: HostBinding,
1604
- args: ['class.longpress']
1605
- }], onMouseDown: [{
1606
- type: HostListener,
1607
- args: ['mousedown', ['$event']]
1608
- }], onMouseMove: [{
1609
- type: HostListener,
1610
- args: ['mousemove', ['$event']]
1611
- }], onMouseUp: [{
1612
- type: HostListener,
1613
- args: ['mouseup']
1614
- }] } });
1615
- ;
1604
+ const log = Log.create(`[firedev-helpers] long-press`, Level.__NOTHING);
1605
+ class LongPress {
1606
+ constructor() {
1607
+ this.pressDuration = 1000;
1608
+ this.onLongPress = new EventEmitter();
1609
+ this.onLongPressing = new EventEmitter();
1610
+ this.onLongPressEnd = new EventEmitter();
1611
+ this.mouseX = 0;
1612
+ this.mouseY = 0;
1613
+ this.allowTrigger = false;
1614
+ this.triggerEnd = _.debounce(() => {
1615
+ this.endPress();
1616
+ }, 500);
1617
+ }
1618
+ get press() { return this.pressing; }
1619
+ get longPress() { return this.longPressing; }
1620
+ onMouseDown(event) {
1621
+ log.d(`MOUSE DOWN `);
1622
+ if (event.which !== 1)
1623
+ return;
1624
+ this.allowTrigger = true;
1625
+ this.mouseX = event.clientX;
1626
+ this.mouseY = event.clientY;
1627
+ this.pressing = true;
1628
+ this.longPressing = false;
1629
+ this.timeout = setTimeout(() => {
1630
+ if (this.allowTrigger) {
1631
+ this.longPressing = true;
1632
+ log.d(`long pressing start pressDuration:${this.pressDuration} `);
1633
+ this.onLongPress.emit(event);
1634
+ this.loop(event);
1635
+ }
1636
+ }, this.pressDuration);
1637
+ this.loop(event);
1638
+ }
1639
+ onMouseMove(event) {
1640
+ if (this.pressing && !this.longPressing) {
1641
+ const xThres = (event.clientX - this.mouseX) > 10;
1642
+ const yThres = (event.clientY - this.mouseY) > 10;
1643
+ if (xThres || yThres) {
1644
+ this.endPress();
1645
+ }
1646
+ }
1647
+ }
1648
+ loop(event) {
1649
+ if (this.longPressing) {
1650
+ this.timeout = setTimeout(() => {
1651
+ log.d(`emil longpressing`);
1652
+ this.triggerEnd();
1653
+ this.onLongPressing.emit(event);
1654
+ this.loop(event);
1655
+ }, 50);
1656
+ }
1657
+ }
1658
+ endPress(emit = true) {
1659
+ this.allowTrigger = false;
1660
+ clearTimeout(this.timeout);
1661
+ this.longPressing = false;
1662
+ this.pressing = false;
1663
+ if (emit) {
1664
+ log.d(`EMIT END`);
1665
+ this.onLongPressEnd.emit(true);
1666
+ }
1667
+ else {
1668
+ log.d(`NOT EMIT END`);
1669
+ }
1670
+ }
1671
+ onMouseUp() {
1672
+ this.endPress(false);
1673
+ }
1674
+ }
1675
+ LongPress.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: LongPress, deps: [], target: i0.ɵɵFactoryTarget.Directive });
1676
+ LongPress.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.12", type: LongPress, selector: "[long-press]", inputs: { pressDuration: "pressDuration" }, outputs: { onLongPress: "onLongPress", onLongPressing: "onLongPressing", onLongPressEnd: "onLongPressEnd" }, host: { listeners: { "mousedown": "onMouseDown($event)", "mousemove": "onMouseMove($event)", "mouseup": "onMouseUp()" }, properties: { "class.press": "this.press", "class.longpress": "this.longPress" } }, ngImport: i0 });
1677
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: LongPress, decorators: [{
1678
+ type: Directive,
1679
+ args: [{ selector: '[long-press]' }]
1680
+ }], propDecorators: { pressDuration: [{
1681
+ type: Input
1682
+ }], onLongPress: [{
1683
+ type: Output
1684
+ }], onLongPressing: [{
1685
+ type: Output
1686
+ }], onLongPressEnd: [{
1687
+ type: Output
1688
+ }], press: [{
1689
+ type: HostBinding,
1690
+ args: ['class.press']
1691
+ }], longPress: [{
1692
+ type: HostBinding,
1693
+ args: ['class.longpress']
1694
+ }], onMouseDown: [{
1695
+ type: HostListener,
1696
+ args: ['mousedown', ['$event']]
1697
+ }], onMouseMove: [{
1698
+ type: HostListener,
1699
+ args: ['mousemove', ['$event']]
1700
+ }], onMouseUp: [{
1701
+ type: HostListener,
1702
+ args: ['mouseup']
1703
+ }] } });
1704
+ ;
1616
1705
  ({}); // @--end-of-file-for-module=tnp-helpers lib/long-press.directive.ts
1617
1706
 
1618
- /* */
1619
- /* */
1620
- const Helpers = HelpersTnp.Instance;
1621
- ;
1707
+ /* */
1708
+ /* */
1709
+ const Helpers = HelpersTnp.Instance;
1710
+ ;
1622
1711
  ({}); // @--end-of-file-for-module=tnp-helpers lib/index.ts
1623
1712
 
1624
- /**
1625
- * Generated bundle index. Do not edit.
1713
+ /**
1714
+ * Generated bundle index. Do not edit.
1626
1715
  */
1627
1716
 
1628
- export { BaseComponent, BaseComponentForRouter, BaseFormlyComponent, BaselineSiteJoinprefix, DualComponentController, Helpers, LongPress, PREFIXES, Project, ResizeService };
1717
+ export { BaseComponent, BaseComponentForRouter, BaseFormlyComponent, BaselineSiteJoinprefix, DualComponentController, Helpers, LongPress, PREFIXES, Project, ResizeService, SerializedSubject };
1629
1718
  //# sourceMappingURL=tnp-helpers.mjs.map