cradova 3.1.3 → 3.1.4
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/LICENSE +183 -183
- package/README.md +31 -30
- package/dist/index.d.ts +36 -16
- package/dist/index.js +72 -34
- package/package.json +1 -1
package/LICENSE
CHANGED
|
@@ -2,180 +2,180 @@
|
|
|
2
2
|
Version 2.0, January 2004
|
|
3
3
|
http://www.apache.org/licenses/
|
|
4
4
|
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
5
|
+
TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
|
|
6
|
+
|
|
7
|
+
1. Definitions.
|
|
8
|
+
|
|
9
|
+
"License" shall mean the terms and conditions for use, reproduction,
|
|
10
|
+
and distribution as defined by Sections 1 through 9 of this document.
|
|
11
|
+
|
|
12
|
+
"Licensor" shall mean the copyright owner or entity authorized by
|
|
13
|
+
the copyright owner that is granting the License.
|
|
14
|
+
|
|
15
|
+
"Legal Entity" shall mean the union of the acting entity and all
|
|
16
|
+
other entities that control, are controlled by, or are under common
|
|
17
|
+
control with that entity. For the purposes of this definition,
|
|
18
|
+
"control" means (i) the power, direct or indirect, to cause the
|
|
19
|
+
direction or management of such entity, whether by contract or
|
|
20
|
+
otherwise, or (ii) ownership of fifty percent (50%) or more of the
|
|
21
|
+
outstanding shares, or (iii) beneficial ownership of such entity.
|
|
22
|
+
|
|
23
|
+
"You" (or "Your") shall mean an individual or Legal Entity
|
|
24
|
+
exercising permissions granted by this License.
|
|
25
|
+
|
|
26
|
+
"Source" form shall mean the preferred form for making modifications,
|
|
27
|
+
including but not limited to software source code, documentation
|
|
28
|
+
source, and configuration files.
|
|
29
|
+
|
|
30
|
+
"Object" form shall mean any form resulting from mechanical
|
|
31
|
+
transformation or translation of a Source form, including but
|
|
32
|
+
not limited to compiled object code, generated documentation,
|
|
33
|
+
and conversions to other media types.
|
|
34
|
+
|
|
35
|
+
"Work" shall mean the work of authorship, whether in Source or
|
|
36
|
+
Object form, made available under the License, as indicated by a
|
|
37
|
+
copyright notice that is included in or attached to the work
|
|
38
|
+
(an example is provided in the Appendix below).
|
|
39
|
+
|
|
40
|
+
"Derivative Works" shall mean any work, whether in Source or Object
|
|
41
|
+
form, that is based on (or derived from) the Work and for which the
|
|
42
|
+
editorial revisions, annotations, elaborations, or other modifications
|
|
43
|
+
represent, as a whole, an original work of authorship. For the purposes
|
|
44
|
+
of this License, Derivative Works shall not include works that remain
|
|
45
|
+
separable from, or merely link (or bind by name) to the interfaces of,
|
|
46
|
+
the Work and Derivative Works thereof.
|
|
47
|
+
|
|
48
|
+
"Contribution" shall mean any work of authorship, including
|
|
49
|
+
the original version of the Work and any modifications or additions
|
|
50
|
+
to that Work or Derivative Works thereof, that is intentionally
|
|
51
|
+
submitted to Licensor for inclusion in the Work by the copyright owner
|
|
52
|
+
or by an individual or Legal Entity authorized to submit on behalf of
|
|
53
|
+
the copyright owner. For the purposes of this definition, "submitted"
|
|
54
|
+
means any form of electronic, verbal, or written communication sent
|
|
55
|
+
to the Licensor or its representatives, including but not limited to
|
|
56
|
+
communication on electronic mailing lists, source code control systems,
|
|
57
|
+
and issue tracking systems that are managed by, or on behalf of, the
|
|
58
|
+
Licensor for the purpose of discussing and improving the Work, but
|
|
59
|
+
excluding communication that is conspicuously marked or otherwise
|
|
60
|
+
designated in writing by the copyright owner as "Not a Contribution."
|
|
61
|
+
|
|
62
|
+
"Contributor" shall mean Licensor and any individual or Legal Entity
|
|
63
|
+
on behalf of whom a Contribution has been received by Licensor and
|
|
64
|
+
subsequently incorporated within the Work.
|
|
65
|
+
|
|
66
|
+
2. Grant of Copyright License. Subject to the terms and conditions of
|
|
67
|
+
this License, each Contributor hereby grants to You a perpetual,
|
|
68
|
+
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
|
69
|
+
copyright license to reproduce, prepare Derivative Works of,
|
|
70
|
+
publicly display, publicly perform, sublicense, and distribute the
|
|
71
|
+
Work and such Derivative Works in Source or Object form.
|
|
72
|
+
|
|
73
|
+
3. Grant of Patent License. Subject to the terms and conditions of
|
|
74
|
+
this License, each Contributor hereby grants to You a perpetual,
|
|
75
|
+
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
|
76
|
+
(except as stated in this section) patent license to make, have made,
|
|
77
|
+
use, offer to sell, sell, import, and otherwise transfer the Work,
|
|
78
|
+
where such license applies only to those patent claims licensable
|
|
79
|
+
by such Contributor that are necessarily infringed by their
|
|
80
|
+
Contribution(s) alone or by combination of their Contribution(s)
|
|
81
|
+
with the Work to which such Contribution(s) was submitted. If You
|
|
82
|
+
institute patent litigation against any entity (including a
|
|
83
|
+
cross-claim or counterclaim in a lawsuit) alleging that the Work
|
|
84
|
+
or a Contribution incorporated within the Work constitutes direct
|
|
85
|
+
or contributory patent infringement, then any patent licenses
|
|
86
|
+
granted to You under this License for that Work shall terminate
|
|
87
|
+
as of the date such litigation is filed.
|
|
88
|
+
|
|
89
|
+
4. Redistribution. You may reproduce and distribute copies of the
|
|
90
|
+
Work or Derivative Works thereof in any medium, with or without
|
|
91
|
+
modifications, and in Source or Object form, provided that You
|
|
92
|
+
meet the following conditions:
|
|
93
|
+
|
|
94
|
+
(a) You must give any other recipients of the Work or
|
|
95
|
+
Derivative Works a copy of this License; and
|
|
96
|
+
|
|
97
|
+
(b) You must cause any modified files to carry prominent notices
|
|
98
|
+
stating that You changed the files; and
|
|
99
|
+
|
|
100
|
+
(c) You must retain, in the Source form of any Derivative Works
|
|
101
|
+
that You distribute, all copyright, patent, trademark, and
|
|
102
|
+
attribution notices from the Source form of the Work,
|
|
103
|
+
excluding those notices that do not pertain to any part of
|
|
104
|
+
the Derivative Works; and
|
|
105
|
+
|
|
106
|
+
(d) If the Work includes a "NOTICE" text file as part of its
|
|
107
|
+
distribution, then any Derivative Works that You distribute must
|
|
108
|
+
include a readable copy of the attribution notices contained
|
|
109
|
+
within such NOTICE file, excluding those notices that do not
|
|
110
|
+
pertain to any part of the Derivative Works, in at least one
|
|
111
|
+
of the following places: within a NOTICE text file distributed
|
|
112
|
+
as part of the Derivative Works; within the Source form or
|
|
113
|
+
documentation, if provided along with the Derivative Works; or,
|
|
114
|
+
within a display generated by the Derivative Works, if and
|
|
115
|
+
wherever such third-party notices normally appear. The contents
|
|
116
|
+
of the NOTICE file are for informational purposes only and
|
|
117
|
+
do not modify the License. You may add Your own attribution
|
|
118
|
+
notices within Derivative Works that You distribute, alongside
|
|
119
|
+
or as an addendum to the NOTICE text from the Work, provided
|
|
120
|
+
that such additional attribution notices cannot be construed
|
|
121
|
+
as modifying the License.
|
|
122
|
+
|
|
123
|
+
You may add Your own copyright statement to Your modifications and
|
|
124
|
+
may provide additional or different license terms and conditions
|
|
125
|
+
for use, reproduction, or distribution of Your modifications, or
|
|
126
|
+
for any such Derivative Works as a whole, provided Your use,
|
|
127
|
+
reproduction, and distribution of the Work otherwise complies with
|
|
128
|
+
the conditions stated in this License.
|
|
129
|
+
|
|
130
|
+
5. Submission of Contributions. Unless You explicitly state otherwise,
|
|
131
|
+
any Contribution intentionally submitted for inclusion in the Work
|
|
132
|
+
by You to the Licensor shall be under the terms and conditions of
|
|
133
|
+
this License, without any additional terms or conditions.
|
|
134
|
+
Notwithstanding the above, nothing herein shall supersede or modify
|
|
135
|
+
the terms of any separate license agreement you may have executed
|
|
136
|
+
with Licensor regarding such Contributions.
|
|
137
|
+
|
|
138
|
+
6. Trademarks. This License does not grant permission to use the trade
|
|
139
|
+
names, trademarks, service marks, or product names of the Licensor,
|
|
140
|
+
except as required for reasonable and customary use in describing the
|
|
141
|
+
origin of the Work and reproducing the content of the NOTICE file.
|
|
142
|
+
|
|
143
|
+
7. Disclaimer of Warranty. Unless required by applicable law or
|
|
144
|
+
agreed to in writing, Licensor provides the Work (and each
|
|
145
|
+
Contributor provides its Contributions) on an "AS IS" BASIS,
|
|
146
|
+
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
|
147
|
+
implied, including, without limitation, any warranties or conditions
|
|
148
|
+
of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
|
|
149
|
+
PARTICULAR PURPOSE. You are solely responsible for determining the
|
|
150
|
+
appropriateness of using or redistributing the Work and assume any
|
|
151
|
+
risks associated with Your exercise of permissions under this License.
|
|
152
|
+
|
|
153
|
+
8. Limitation of Liability. In no event and under no legal theory,
|
|
154
|
+
whether in tort (including negligence), contract, or otherwise,
|
|
155
|
+
unless required by applicable law (such as deliberate and grossly
|
|
156
|
+
negligent acts) or agreed to in writing, shall any Contributor be
|
|
157
|
+
liable to You for damages, including any direct, indirect, special,
|
|
158
|
+
incidental, or consequential damages of any character arising as a
|
|
159
|
+
result of this License or out of the use or inability to use the
|
|
160
|
+
Work (including but not limited to damages for loss of goodwill,
|
|
161
|
+
work stoppage, computer failure or malfunction, or any and all
|
|
162
|
+
other commercial damages or losses), even if such Contributor
|
|
163
|
+
has been advised of the possibility of such damages.
|
|
164
|
+
|
|
165
|
+
9. Accepting Warranty or Additional Liability. While redistributing
|
|
166
|
+
the Work or Derivative Works thereof, You may choose to offer,
|
|
167
|
+
and charge a fee for, acceptance of support, warranty, indemnity,
|
|
168
|
+
or other liability obligations and/or rights consistent with this
|
|
169
|
+
License. However, in accepting such obligations, You may act only
|
|
170
|
+
on Your own behalf and on Your sole responsibility, not on behalf
|
|
171
|
+
of any other Contributor, and only if You agree to indemnify,
|
|
172
|
+
defend, and hold each Contributor harmless for any liability
|
|
173
|
+
incurred by, or claims asserted against, such Contributor by reason
|
|
174
|
+
of your accepting any such warranty or additional liability.
|
|
175
|
+
|
|
176
|
+
END OF TERMS AND CONDITIONS
|
|
177
|
+
|
|
178
|
+
APPENDIX: How to apply the Apache License to your work.
|
|
179
179
|
|
|
180
180
|
To apply the Apache License to your work, attach the following
|
|
181
181
|
boilerplate notice, with the fields enclosed by brackets "[]"
|
|
@@ -186,16 +186,16 @@
|
|
|
186
186
|
same "printed page" as the copyright notice for easier
|
|
187
187
|
identification within third-party archives.
|
|
188
188
|
|
|
189
|
-
|
|
189
|
+
Copyright 2023 friday candour
|
|
190
190
|
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
191
|
+
Licensed under the Apache License, Version 2.0 (the "License");
|
|
192
|
+
you may not use this file except in compliance with the License.
|
|
193
|
+
You may obtain a copy of the License at
|
|
194
194
|
|
|
195
195
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
196
196
|
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
197
|
+
Unless required by applicable law or agreed to in writing, software
|
|
198
|
+
distributed under the License is distributed on an "AS IS" BASIS,
|
|
199
|
+
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
200
|
+
See the License for the specific language governing permissions and
|
|
201
|
+
limitations under the License.
|
package/README.md
CHANGED
|
@@ -43,13 +43,13 @@ Cradova is a web development framework for building Single Page Applications and
|
|
|
43
43
|
|
|
44
44
|
It's a fast and simple framework, it provides an easy to use state management and router system.
|
|
45
45
|
|
|
46
|
-
Cradova follows the [VJS specification](https://github.com/
|
|
46
|
+
Cradova follows the [VJS specification](https://github.com/FridayCandour/cradova/blob/main/VJS_spec/spec.md)
|
|
47
47
|
|
|
48
48
|
## What's the benefit?
|
|
49
49
|
|
|
50
50
|
Cradova is aimed to be fast and simple with and fewer abstractions and yet easily composable.
|
|
51
51
|
|
|
52
|
-
Cradova is not built on
|
|
52
|
+
Cradova is not built on virtual DOM or diff algorithms.
|
|
53
53
|
Instead, State management is done more elegantly with a simple predictive model, simple and easy with all the speed.
|
|
54
54
|
|
|
55
55
|
## Is this a big benefit?
|
|
@@ -62,24 +62,21 @@ Cradova has already been utilized in multiple production projects, and we will c
|
|
|
62
62
|
|
|
63
63
|
## Installation
|
|
64
64
|
|
|
65
|
+
### From npm
|
|
66
|
+
|
|
67
|
+
```bash
|
|
68
|
+
npm i cradova
|
|
69
|
+
```
|
|
70
|
+
|
|
65
71
|
### CDN sources
|
|
66
72
|
|
|
67
73
|
```html
|
|
68
74
|
<!-- unpkg -->
|
|
69
|
-
|
|
70
75
|
<script src="https://unpkg.com/cradova/dist/index.js"></script>
|
|
71
|
-
|
|
72
76
|
<!-- js deliver -->
|
|
73
|
-
|
|
74
77
|
<script src="https://cdn.jsdelivr.net/npm/cradova/dist/index.js"></script>
|
|
75
78
|
```
|
|
76
79
|
|
|
77
|
-
### npm
|
|
78
|
-
|
|
79
|
-
```bash
|
|
80
|
-
npm i cradova
|
|
81
|
-
```
|
|
82
|
-
|
|
83
80
|
## Examples
|
|
84
81
|
|
|
85
82
|
Many aspects of Cradova are not reflected in the following example. More functionality will be entailed in future docs.
|
|
@@ -155,7 +152,7 @@ function HelloMessage() {
|
|
|
155
152
|
});
|
|
156
153
|
}
|
|
157
154
|
|
|
158
|
-
// using
|
|
155
|
+
// using CradovaRef
|
|
159
156
|
|
|
160
157
|
const nameRef = new Ref(function (name) {
|
|
161
158
|
const self = this;
|
|
@@ -190,8 +187,6 @@ function App() {
|
|
|
190
187
|
return div(count, counter, dataCounter, HelloMessage, br, nameRef);
|
|
191
188
|
}
|
|
192
189
|
|
|
193
|
-
// add your app to the DOM
|
|
194
|
-
|
|
195
190
|
document.body.append(App());
|
|
196
191
|
```
|
|
197
192
|
|
|
@@ -201,20 +196,26 @@ Let's see a simple TodoList example
|
|
|
201
196
|
|
|
202
197
|
```js
|
|
203
198
|
import _, {
|
|
204
|
-
|
|
205
|
-
createSignal,
|
|
206
|
-
css,
|
|
199
|
+
// elements
|
|
207
200
|
div,
|
|
208
|
-
|
|
201
|
+
button,
|
|
209
202
|
main,
|
|
210
203
|
p,
|
|
204
|
+
input,
|
|
205
|
+
// allows you to create powerful data stores
|
|
206
|
+
createSignal,
|
|
207
|
+
// dom ref
|
|
208
|
+
useRef(),
|
|
209
|
+
// useState
|
|
210
|
+
// useEffect
|
|
211
|
+
// dynamic component class
|
|
211
212
|
Ref,
|
|
212
|
-
|
|
213
|
+
css,
|
|
213
214
|
} from "cradova";
|
|
214
215
|
|
|
215
216
|
function TodoList() {
|
|
216
217
|
// can be used to hold multiple references
|
|
217
|
-
const referenceSet =
|
|
218
|
+
const referenceSet = useRef();
|
|
218
219
|
|
|
219
220
|
// creating a store
|
|
220
221
|
const todoStore = new createSignal([
|
|
@@ -355,21 +356,21 @@ Router.onPageEvent((lastRoute, newRoute) => {
|
|
|
355
356
|
|
|
356
357
|
---
|
|
357
358
|
|
|
358
|
-
More info on
|
|
359
|
+
More info on Cradova Router
|
|
359
360
|
|
|
360
361
|
---
|
|
361
362
|
|
|
362
|
-
Every
|
|
363
|
+
Every Cradova app mounts on a div with attribute data-wrapper="app"
|
|
363
364
|
|
|
364
|
-
if it already exist
|
|
365
|
+
if it already exist Cradova will use it instead.
|
|
365
366
|
|
|
366
|
-
|
|
367
|
+
Cradova will create a div with data-wrapper="app" if it doesn't exists already.
|
|
367
368
|
|
|
368
369
|
so if you want to use your own mount point then create a div with data-wrapper="app".
|
|
369
370
|
|
|
370
371
|
---
|
|
371
372
|
|
|
372
|
-
More info on
|
|
373
|
+
More info on Cradova screens
|
|
373
374
|
|
|
374
375
|
---
|
|
375
376
|
|
|
@@ -391,11 +392,11 @@ circle for each screen in your app
|
|
|
391
392
|
|
|
392
393
|
---
|
|
393
394
|
|
|
394
|
-
More info on
|
|
395
|
+
More info on Cradova Ref
|
|
395
396
|
|
|
396
397
|
---
|
|
397
398
|
|
|
398
|
-
|
|
399
|
+
Cradova Ref is a dynamic component class, which ships simple abstractions like:
|
|
399
400
|
|
|
400
401
|
- Effects
|
|
401
402
|
- stash
|
|
@@ -407,7 +408,7 @@ circle for refs in your app
|
|
|
407
408
|
|
|
408
409
|
---
|
|
409
410
|
|
|
410
|
-
More info on
|
|
411
|
+
More info on Cradova createSignal
|
|
411
412
|
|
|
412
413
|
---
|
|
413
414
|
|
|
@@ -420,7 +421,7 @@ with ability to:
|
|
|
420
421
|
- bind a Ref
|
|
421
422
|
- listen to changes
|
|
422
423
|
- persist changes to localStorage
|
|
423
|
-
- update a
|
|
424
|
+
- update a CradovaRef and bindings automatically
|
|
424
425
|
|
|
425
426
|
With these simple and easy abstractions, you can use datastores with powerful convenience.
|
|
426
427
|
|
|
@@ -436,7 +437,7 @@ To get further insights and help on Cradova, visit our [Discord](https://discord
|
|
|
436
437
|
|
|
437
438
|
We are currently working to [set](https://github.com/fridaycandour/cradova/blob/main/contributing.md) up the following:
|
|
438
439
|
|
|
439
|
-
- building
|
|
440
|
+
- building Cradova CLI (in progress)
|
|
440
441
|
- Cradova Documentation Website
|
|
441
442
|
- UI component libraries for cradova
|
|
442
443
|
- Sample projects
|
package/dist/index.d.ts
CHANGED
|
@@ -137,8 +137,8 @@ declare module "cradova" {
|
|
|
137
137
|
*/
|
|
138
138
|
export class cradovaEvent {
|
|
139
139
|
private listeners;
|
|
140
|
-
addEventListener(eventName: string, callback: () => void): void
|
|
141
|
-
dispatchEvent(eventName: string, eventArgs?: unknown): void
|
|
140
|
+
addEventListener(eventName: string, callback: () => void): Promise<void>;
|
|
141
|
+
dispatchEvent(eventName: string, eventArgs?: unknown): Promise<void>;
|
|
142
142
|
}
|
|
143
143
|
export const CradovaEvent: cradovaEvent;
|
|
144
144
|
export function Rhoda(
|
|
@@ -241,6 +241,7 @@ declare module "cradova" {
|
|
|
241
241
|
export class reference {
|
|
242
242
|
[x: string]: Record<string, any>;
|
|
243
243
|
bindAs(name: string): reference;
|
|
244
|
+
dom<ElementType>(name: string): ElementType | undefined;
|
|
244
245
|
_appendDomForce(name: string, Element: HTMLElement): void;
|
|
245
246
|
}
|
|
246
247
|
/**
|
|
@@ -290,7 +291,6 @@ declare module "cradova" {
|
|
|
290
291
|
/**
|
|
291
292
|
* this is a set of added html to the screen
|
|
292
293
|
*/
|
|
293
|
-
_secondaryChildren: VJSType<HTMLElement>[];
|
|
294
294
|
/**
|
|
295
295
|
* error handler for the screen
|
|
296
296
|
*/
|
|
@@ -306,6 +306,7 @@ declare module "cradova" {
|
|
|
306
306
|
private _persist;
|
|
307
307
|
private _delegatedRoutesCount;
|
|
308
308
|
private _transition;
|
|
309
|
+
private _dropped;
|
|
309
310
|
constructor(cradova_screen_initials: CradovaScreenType);
|
|
310
311
|
get _delegatedRoutes(): boolean;
|
|
311
312
|
set _delegatedRoutes(count: boolean);
|
|
@@ -313,8 +314,8 @@ declare module "cradova" {
|
|
|
313
314
|
_package(): Promise<void>;
|
|
314
315
|
onActivate(cb: () => Promise<void> | void): void;
|
|
315
316
|
onDeactivate(cb: () => Promise<void> | void): void;
|
|
316
|
-
addChildren(...addOns: VJSType<HTMLElement>[]): void;
|
|
317
317
|
_deActivate(): Promise<void>;
|
|
318
|
+
drop(state: boolean): boolean | undefined;
|
|
318
319
|
_Activate(force?: boolean): Promise<void>;
|
|
319
320
|
}
|
|
320
321
|
|
|
@@ -513,7 +514,7 @@ declare module "cradova" {
|
|
|
513
514
|
* @param {string} path Route path.
|
|
514
515
|
* @param screen the cradova document tree for the route.
|
|
515
516
|
*/
|
|
516
|
-
export class
|
|
517
|
+
export class Router {
|
|
517
518
|
/** cradova router
|
|
518
519
|
* ---
|
|
519
520
|
* Registers a route.
|
|
@@ -523,15 +524,23 @@ declare module "cradova" {
|
|
|
523
524
|
* @param {string} path Route path.
|
|
524
525
|
* @param screen the cradova screen.
|
|
525
526
|
*/
|
|
526
|
-
BrowserRoutes(obj: Record<string, any>): void;
|
|
527
|
+
static BrowserRoutes(obj: Record<string, any>): void;
|
|
527
528
|
/**
|
|
528
529
|
Go back in Navigation history
|
|
529
530
|
*/
|
|
530
|
-
back(): void;
|
|
531
|
+
static back(): void;
|
|
531
532
|
/**
|
|
532
533
|
Go forward in Navigation history
|
|
533
534
|
*/
|
|
534
|
-
forward(): void;
|
|
535
|
+
static forward(): void;
|
|
536
|
+
/**
|
|
537
|
+
Pause navigation
|
|
538
|
+
*/
|
|
539
|
+
static pauseNaviagtion(): void;
|
|
540
|
+
/**
|
|
541
|
+
resume navigation
|
|
542
|
+
*/
|
|
543
|
+
static resumeNaviagtion(): void;
|
|
535
544
|
/**
|
|
536
545
|
* Cradova Router
|
|
537
546
|
* ------
|
|
@@ -542,11 +551,20 @@ declare module "cradova" {
|
|
|
542
551
|
* @param data object
|
|
543
552
|
* @param force boolean
|
|
544
553
|
*/
|
|
545
|
-
navigate(
|
|
554
|
+
static navigate(
|
|
546
555
|
href: string,
|
|
547
556
|
data?: Record<string, unknown> | null,
|
|
548
557
|
force?: boolean
|
|
549
558
|
): void;
|
|
559
|
+
/**
|
|
560
|
+
* Cradova Router
|
|
561
|
+
* ------
|
|
562
|
+
*
|
|
563
|
+
* Navigates to a designated screen in your app by loading a seperate page;
|
|
564
|
+
*
|
|
565
|
+
* @param pathname string
|
|
566
|
+
*/
|
|
567
|
+
static navigateNauturally(pathname: string): void;
|
|
550
568
|
/**
|
|
551
569
|
* Cradova
|
|
552
570
|
* ---
|
|
@@ -556,14 +574,14 @@ declare module "cradova" {
|
|
|
556
574
|
*
|
|
557
575
|
* @param screen
|
|
558
576
|
*/
|
|
559
|
-
setLoadingScreen(screen: Screen): void;
|
|
577
|
+
static setLoadingScreen(screen: Screen): void;
|
|
560
578
|
/** cradova router
|
|
561
579
|
* ---
|
|
562
580
|
* Listen for navigation events
|
|
563
581
|
*
|
|
564
582
|
* @param callback () => void
|
|
565
583
|
*/
|
|
566
|
-
onPageEvent(callback: () => void): void;
|
|
584
|
+
static onPageEvent(callback: () => void): void;
|
|
567
585
|
/** cradova router
|
|
568
586
|
* ---
|
|
569
587
|
* get a screen ready before time.
|
|
@@ -571,7 +589,10 @@ declare module "cradova" {
|
|
|
571
589
|
* @param {string} path Route path.
|
|
572
590
|
* @param data data for the screen.
|
|
573
591
|
*/
|
|
574
|
-
packageScreen(
|
|
592
|
+
static packageScreen(
|
|
593
|
+
path: string,
|
|
594
|
+
data?: Record<string, unknown>
|
|
595
|
+
): Promise<void>;
|
|
575
596
|
/**
|
|
576
597
|
* Cradova Router
|
|
577
598
|
* ------
|
|
@@ -580,7 +601,7 @@ declare module "cradova" {
|
|
|
580
601
|
*
|
|
581
602
|
* .
|
|
582
603
|
*/
|
|
583
|
-
getParams(): any;
|
|
604
|
+
static getParams(): any;
|
|
584
605
|
/**
|
|
585
606
|
* Cradova
|
|
586
607
|
* ---
|
|
@@ -589,10 +610,9 @@ declare module "cradova" {
|
|
|
589
610
|
* @param callback
|
|
590
611
|
* @param path? page path
|
|
591
612
|
*/
|
|
592
|
-
addErrorHandler(callback: (err: unknown) => void): void;
|
|
593
|
-
_mount(): void;
|
|
613
|
+
static addErrorHandler(callback: (err: unknown) => void): void;
|
|
614
|
+
static _mount(): void;
|
|
594
615
|
}
|
|
595
|
-
export const Router: RouterClass;
|
|
596
616
|
|
|
597
617
|
/**
|
|
598
618
|
*
|
package/dist/index.js
CHANGED
|
@@ -21,7 +21,7 @@ var cradovaEvent = class {
|
|
|
21
21
|
constructor() {
|
|
22
22
|
this.listeners = {};
|
|
23
23
|
}
|
|
24
|
-
addEventListener(eventName, callback) {
|
|
24
|
+
async addEventListener(eventName, callback) {
|
|
25
25
|
if (!this.listeners[eventName]) {
|
|
26
26
|
this.listeners[eventName] = [];
|
|
27
27
|
}
|
|
@@ -30,7 +30,7 @@ var cradovaEvent = class {
|
|
|
30
30
|
// removeEventListener(eventName: string, num: number) {
|
|
31
31
|
// this.listeners[eventName].splice(num, 1);
|
|
32
32
|
// }
|
|
33
|
-
dispatchEvent(eventName, eventArgs) {
|
|
33
|
+
async dispatchEvent(eventName, eventArgs) {
|
|
34
34
|
const eventListeners = this.listeners[eventName] || [];
|
|
35
35
|
for (; eventListeners.length !== 0; ) {
|
|
36
36
|
eventListeners.shift()?.call(void 0, eventArgs);
|
|
@@ -281,6 +281,9 @@ var reference = class {
|
|
|
281
281
|
bindAs(name) {
|
|
282
282
|
return [this, name];
|
|
283
283
|
}
|
|
284
|
+
dom(name) {
|
|
285
|
+
return this[name];
|
|
286
|
+
}
|
|
284
287
|
_appendDomForce(name, Element) {
|
|
285
288
|
this[name] = Element;
|
|
286
289
|
}
|
|
@@ -611,7 +614,7 @@ var Screen = class {
|
|
|
611
614
|
/**
|
|
612
615
|
* this is a set of added html to the screen
|
|
613
616
|
*/
|
|
614
|
-
|
|
617
|
+
// private _secondaryChildren: VJSType<HTMLElement>[] = [];
|
|
615
618
|
/**
|
|
616
619
|
* error handler for the screen
|
|
617
620
|
*/
|
|
@@ -620,6 +623,7 @@ var Screen = class {
|
|
|
620
623
|
this._template = document.createElement("div");
|
|
621
624
|
this._persist = true;
|
|
622
625
|
this._delegatedRoutesCount = -1;
|
|
626
|
+
this._dropped = false;
|
|
623
627
|
const { template: template2, name, persist, renderInParallel, transition } = cradova_screen_initials;
|
|
624
628
|
this._html = template2;
|
|
625
629
|
this._name = name;
|
|
@@ -668,9 +672,6 @@ var Screen = class {
|
|
|
668
672
|
}
|
|
669
673
|
}
|
|
670
674
|
}
|
|
671
|
-
if (this._secondaryChildren.length) {
|
|
672
|
-
this._template.appendChild(frag(this._secondaryChildren));
|
|
673
|
-
}
|
|
674
675
|
}
|
|
675
676
|
onActivate(cb) {
|
|
676
677
|
this._callBack = cb;
|
|
@@ -678,15 +679,26 @@ var Screen = class {
|
|
|
678
679
|
onDeactivate(cb) {
|
|
679
680
|
this._deCallBack = cb;
|
|
680
681
|
}
|
|
681
|
-
addChildren(...addOns) {
|
|
682
|
-
|
|
683
|
-
}
|
|
682
|
+
// addChildren(...addOns: VJSType<HTMLElement>[]) {
|
|
683
|
+
// this._secondaryChildren.push(...addOns);
|
|
684
|
+
// }
|
|
684
685
|
async _deActivate() {
|
|
685
686
|
if (this._deCallBack) {
|
|
686
687
|
await this._deCallBack();
|
|
687
688
|
}
|
|
688
689
|
}
|
|
690
|
+
drop(state) {
|
|
691
|
+
if (typeof state === "boolean") {
|
|
692
|
+
this._dropped = state;
|
|
693
|
+
return void 0;
|
|
694
|
+
} else
|
|
695
|
+
return this._dropped;
|
|
696
|
+
}
|
|
689
697
|
async _Activate(force = false) {
|
|
698
|
+
if (this._dropped) {
|
|
699
|
+
history.go(-1);
|
|
700
|
+
return;
|
|
701
|
+
}
|
|
690
702
|
if (!this._persist || force || !this._packed) {
|
|
691
703
|
await this._package();
|
|
692
704
|
this._packed = true;
|
|
@@ -722,6 +734,7 @@ RouterBox["loadingScreen"] = null;
|
|
|
722
734
|
RouterBox["params"] = {};
|
|
723
735
|
RouterBox["routes"] = {};
|
|
724
736
|
RouterBox["pageevents"] = [];
|
|
737
|
+
RouterBox["paused"] = false;
|
|
725
738
|
RouterBox["start_pageevents"] = async function(url) {
|
|
726
739
|
setTimeout(() => {
|
|
727
740
|
for (let ci = 0; ci < RouterBox["pageevents"].length; ci++) {
|
|
@@ -784,9 +797,10 @@ RouterBox.route = (path, screen) => {
|
|
|
784
797
|
return void 0;
|
|
785
798
|
};
|
|
786
799
|
RouterBox.router = async function(_e, _force) {
|
|
787
|
-
let url, route, params;
|
|
788
|
-
if (
|
|
789
|
-
|
|
800
|
+
let url = window.location.pathname, route, params;
|
|
801
|
+
if (RouterBox["paused"]) {
|
|
802
|
+
window.location.hash = "paused";
|
|
803
|
+
return;
|
|
790
804
|
}
|
|
791
805
|
if (url === RouterBox["lastNavigatedRoute"]) {
|
|
792
806
|
return;
|
|
@@ -847,7 +861,7 @@ RouterBox.router = async function(_e, _force) {
|
|
|
847
861
|
}
|
|
848
862
|
}
|
|
849
863
|
};
|
|
850
|
-
var
|
|
864
|
+
var Router = class {
|
|
851
865
|
/** cradova router
|
|
852
866
|
* ---
|
|
853
867
|
* Registers a route.
|
|
@@ -857,7 +871,7 @@ var RouterClass = class {
|
|
|
857
871
|
* @param {string} path Route path.
|
|
858
872
|
* @param screen the cradova screen.
|
|
859
873
|
*/
|
|
860
|
-
BrowserRoutes(obj) {
|
|
874
|
+
static BrowserRoutes(obj) {
|
|
861
875
|
for (const path in obj) {
|
|
862
876
|
let screen = obj[path];
|
|
863
877
|
if (typeof screen === "object" && typeof screen.then === "function" || typeof screen === "function") {
|
|
@@ -869,20 +883,35 @@ var RouterClass = class {
|
|
|
869
883
|
RouterBox.route(path, screen);
|
|
870
884
|
}
|
|
871
885
|
}
|
|
872
|
-
|
|
886
|
+
Router._mount();
|
|
873
887
|
}
|
|
874
888
|
/**
|
|
875
889
|
Go back in Navigation history
|
|
876
890
|
*/
|
|
877
|
-
back() {
|
|
891
|
+
static back() {
|
|
878
892
|
history.go(-1);
|
|
879
893
|
}
|
|
880
894
|
/**
|
|
881
895
|
Go forward in Navigation history
|
|
882
896
|
*/
|
|
883
|
-
forward() {
|
|
897
|
+
static forward() {
|
|
884
898
|
history.go(1);
|
|
885
899
|
}
|
|
900
|
+
/**
|
|
901
|
+
Pause navigation
|
|
902
|
+
*/
|
|
903
|
+
static pauseNaviagtion() {
|
|
904
|
+
RouterBox["paused"] = true;
|
|
905
|
+
window.location.hash = "paused";
|
|
906
|
+
}
|
|
907
|
+
/**
|
|
908
|
+
resume navigation
|
|
909
|
+
*/
|
|
910
|
+
static resumeNaviagtion() {
|
|
911
|
+
RouterBox["paused"] = false;
|
|
912
|
+
window.location.replace(window.location.pathname + window.location.search);
|
|
913
|
+
history.go(-1);
|
|
914
|
+
}
|
|
886
915
|
/**
|
|
887
916
|
* Cradova Router
|
|
888
917
|
* ------
|
|
@@ -893,7 +922,7 @@ var RouterClass = class {
|
|
|
893
922
|
* @param data object
|
|
894
923
|
* @param force boolean
|
|
895
924
|
*/
|
|
896
|
-
navigate(href, data2 = null, force = false) {
|
|
925
|
+
static navigate(href, data2 = null, force = false) {
|
|
897
926
|
if (typeof href !== "string") {
|
|
898
927
|
throw new TypeError(
|
|
899
928
|
" \u2718 Cradova err: href must be a defined path but got " + href + " instead"
|
|
@@ -916,6 +945,22 @@ var RouterClass = class {
|
|
|
916
945
|
RouterBox.router(null, force);
|
|
917
946
|
}
|
|
918
947
|
}
|
|
948
|
+
/**
|
|
949
|
+
* Cradova Router
|
|
950
|
+
* ------
|
|
951
|
+
*
|
|
952
|
+
* Navigates to a designated screen in your app by loading a seperate page;
|
|
953
|
+
*
|
|
954
|
+
* @param pathname string
|
|
955
|
+
*/
|
|
956
|
+
static navigateNauturally(pathname) {
|
|
957
|
+
if (typeof pathname !== "string") {
|
|
958
|
+
throw new TypeError(
|
|
959
|
+
" \u2718 Cradova err: pathname must be a defined path but got " + pathname + " instead"
|
|
960
|
+
);
|
|
961
|
+
}
|
|
962
|
+
window.location.pathname = pathname;
|
|
963
|
+
}
|
|
919
964
|
/**
|
|
920
965
|
* Cradova
|
|
921
966
|
* ---
|
|
@@ -925,7 +970,7 @@ var RouterClass = class {
|
|
|
925
970
|
*
|
|
926
971
|
* @param screen
|
|
927
972
|
*/
|
|
928
|
-
setLoadingScreen(screen) {
|
|
973
|
+
static setLoadingScreen(screen) {
|
|
929
974
|
if (screen instanceof Screen) {
|
|
930
975
|
RouterBox["LoadingScreen"] = screen;
|
|
931
976
|
} else {
|
|
@@ -940,7 +985,7 @@ var RouterClass = class {
|
|
|
940
985
|
*
|
|
941
986
|
* @param callback () => void
|
|
942
987
|
*/
|
|
943
|
-
onPageEvent(callback) {
|
|
988
|
+
static onPageEvent(callback) {
|
|
944
989
|
if (typeof callback === "function") {
|
|
945
990
|
RouterBox["pageevents"].push(callback);
|
|
946
991
|
} else {
|
|
@@ -956,7 +1001,7 @@ var RouterClass = class {
|
|
|
956
1001
|
* @param {string} path Route path.
|
|
957
1002
|
* @param data data for the screen.
|
|
958
1003
|
*/
|
|
959
|
-
async packageScreen(path, data2 = {}) {
|
|
1004
|
+
static async packageScreen(path, data2 = {}) {
|
|
960
1005
|
if (!RouterBox.routes[path]) {
|
|
961
1006
|
console.error(" \u2718 Cradova err: no screen with path " + path);
|
|
962
1007
|
throw new Error(
|
|
@@ -986,7 +1031,7 @@ var RouterClass = class {
|
|
|
986
1031
|
*
|
|
987
1032
|
* .
|
|
988
1033
|
*/
|
|
989
|
-
getParams() {
|
|
1034
|
+
static getParams() {
|
|
990
1035
|
return RouterBox["params"];
|
|
991
1036
|
}
|
|
992
1037
|
/**
|
|
@@ -997,7 +1042,7 @@ var RouterClass = class {
|
|
|
997
1042
|
* @param callback
|
|
998
1043
|
* @param path? page path
|
|
999
1044
|
*/
|
|
1000
|
-
addErrorHandler(callback) {
|
|
1045
|
+
static addErrorHandler(callback) {
|
|
1001
1046
|
if (typeof callback === "function") {
|
|
1002
1047
|
RouterBox["errorHandler"] = callback;
|
|
1003
1048
|
} else {
|
|
@@ -1006,7 +1051,7 @@ var RouterClass = class {
|
|
|
1006
1051
|
);
|
|
1007
1052
|
}
|
|
1008
1053
|
}
|
|
1009
|
-
_mount() {
|
|
1054
|
+
static _mount() {
|
|
1010
1055
|
let doc = document.querySelector("[data-wrapper=app]");
|
|
1011
1056
|
if (!doc) {
|
|
1012
1057
|
doc = document.createElement("div");
|
|
@@ -1023,7 +1068,6 @@ var RouterClass = class {
|
|
|
1023
1068
|
});
|
|
1024
1069
|
}
|
|
1025
1070
|
};
|
|
1026
|
-
var Router = new RouterClass();
|
|
1027
1071
|
|
|
1028
1072
|
// lib/parts/elements.ts
|
|
1029
1073
|
var makeElement = (element, ElementChildrenAndPropertyList) => {
|
|
@@ -1053,12 +1097,6 @@ var makeElement = (element, ElementChildrenAndPropertyList) => {
|
|
|
1053
1097
|
props = Object.assign(props, child);
|
|
1054
1098
|
continue;
|
|
1055
1099
|
}
|
|
1056
|
-
if (typeof child !== "undefined") {
|
|
1057
|
-
console.error(" \u2718 Cradova err: got", { child });
|
|
1058
|
-
throw new Error(
|
|
1059
|
-
" \u2718 Cradova err: invalid child type: (" + typeof child + ")"
|
|
1060
|
-
);
|
|
1061
|
-
}
|
|
1062
1100
|
}
|
|
1063
1101
|
} else {
|
|
1064
1102
|
return element;
|
|
@@ -1139,8 +1177,8 @@ var makeElement = (element, ElementChildrenAndPropertyList) => {
|
|
|
1139
1177
|
return element;
|
|
1140
1178
|
};
|
|
1141
1179
|
var make = function(descriptor) {
|
|
1142
|
-
if (
|
|
1143
|
-
return [
|
|
1180
|
+
if (typeof descriptor !== "string") {
|
|
1181
|
+
return [];
|
|
1144
1182
|
}
|
|
1145
1183
|
if (Array.isArray(descriptor)) {
|
|
1146
1184
|
descriptor = descriptor[0];
|
|
@@ -1193,7 +1231,7 @@ var make = function(descriptor) {
|
|
|
1193
1231
|
}
|
|
1194
1232
|
classes.push(descriptor[i2]);
|
|
1195
1233
|
}
|
|
1196
|
-
return [tag
|
|
1234
|
+
return [tag, IDs[0], classes.join(" "), innerValue];
|
|
1197
1235
|
};
|
|
1198
1236
|
var cra = (tag) => {
|
|
1199
1237
|
const extend = (...Children_and_Properties) => makeElement(document.createElement(tag), Children_and_Properties);
|