@zentered/issue-forms-body-parser 1.5.1 → 2.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,11 +1,11 @@
1
- name: "CodeQL"
1
+ name: 'CodeQL'
2
2
 
3
3
  on:
4
4
  push:
5
- branches: [ main ]
5
+ branches: [main]
6
6
  pull_request:
7
7
  # The branches below must be a subset of the branches above
8
- branches: [ main ]
8
+ branches: [main]
9
9
  schedule:
10
10
  - cron: '29 21 * * 5'
11
11
 
@@ -21,39 +21,39 @@ jobs:
21
21
  strategy:
22
22
  fail-fast: false
23
23
  matrix:
24
- language: [ 'javascript' ]
24
+ language: ['javascript']
25
25
  # CodeQL supports [ 'cpp', 'csharp', 'go', 'java', 'javascript', 'python', 'ruby' ]
26
26
  # Learn more about CodeQL language support at https://git.io/codeql-language-support
27
27
 
28
28
  steps:
29
- - name: Checkout repository
30
- uses: actions/checkout@v3
31
-
32
- # Initializes the CodeQL tools for scanning.
33
- - name: Initialize CodeQL
34
- uses: github/codeql-action/init@v2
35
- with:
36
- languages: ${{ matrix.language }}
37
- # If you wish to specify custom queries, you can do so here or in a config file.
38
- # By default, queries listed here will override any specified in a config file.
39
- # Prefix the list here with "+" to use these queries and those in the config file.
40
- # queries: ./path/to/local/query, your-org/your-repo/queries@main
41
-
42
- # Autobuild attempts to build any compiled languages (C/C++, C#, or Java).
43
- # If this step fails, then you should remove it and run the build manually (see below)
44
- - name: Autobuild
45
- uses: github/codeql-action/autobuild@v2
46
-
47
- # ℹ️ Command-line programs to run using the OS shell.
48
- # 📚 https://git.io/JvXDl
49
-
50
- # ✏️ If the Autobuild fails above, remove it and uncomment the following three lines
51
- # and modify them (or add more) to build your code if your project
52
- # uses a compiled language
53
-
54
- #- run: |
55
- # make bootstrap
56
- # make release
57
-
58
- - name: Perform CodeQL Analysis
59
- uses: github/codeql-action/analyze@v2
29
+ - name: Checkout repository
30
+ uses: actions/checkout@v3
31
+
32
+ # Initializes the CodeQL tools for scanning.
33
+ - name: Initialize CodeQL
34
+ uses: github/codeql-action/init@v2
35
+ with:
36
+ languages: ${{ matrix.language }}
37
+ # If you wish to specify custom queries, you can do so here or in a config file.
38
+ # By default, queries listed here will override any specified in a config file.
39
+ # Prefix the list here with "+" to use these queries and those in the config file.
40
+ # queries: ./path/to/local/query, your-org/your-repo/queries@main
41
+
42
+ # Autobuild attempts to build any compiled languages (C/C++, C#, or Java).
43
+ # If this step fails, then you should remove it and run the build manually (see below)
44
+ - name: Autobuild
45
+ uses: github/codeql-action/autobuild@v2
46
+
47
+ # ℹ️ Command-line programs to run using the OS shell.
48
+ # 📚 https://git.io/JvXDl
49
+
50
+ # ✏️ If the Autobuild fails above, remove it and uncomment the following three lines
51
+ # and modify them (or add more) to build your code if your project
52
+ # uses a compiled language
53
+
54
+ #- run: |
55
+ # make bootstrap
56
+ # make release
57
+
58
+ - name: Perform CodeQL Analysis
59
+ uses: github/codeql-action/analyze@v2
@@ -10,4 +10,17 @@ jobs:
10
10
  - name: Issue Forms Body Parser
11
11
  id: parse
12
12
  uses: ./
13
- - run: echo "${{ toJSON(steps.parse.outputs.data) }}"
13
+ - run: echo ${{ toJSON(steps.parse.outputs.data) }}
14
+
15
+ - name: Read an issue content
16
+ id: read_issue
17
+ run: |
18
+ echo "body<<EOF" >> $GITHUB_OUTPUT
19
+ cat ./test/test-issue-3.md >> $GITHUB_OUTPUT
20
+ echo "EOF" >> $GITHUB_OUTPUT
21
+ - name: Issue Forms Body Parser With Provided Body
22
+ id: parse_with_body
23
+ uses: ./
24
+ with:
25
+ body: ${{ steps.read_issue.outputs.body }}
26
+ - run: echo ${{ toJSON(steps.parse_with_body.outputs.data) }}
@@ -19,6 +19,10 @@ jobs:
19
19
  runs-on: ubuntu-latest
20
20
  steps:
21
21
  - uses: actions/checkout@v3
22
+ - uses: actions/setup-node@v3
23
+ with:
24
+ node-version: 18
25
+ cache: 'npm'
22
26
  - run: npm ci
23
27
  - run: npm test
24
28
  - run: npm run release
@@ -17,8 +17,33 @@ jobs:
17
17
  runs-on: ubuntu-latest
18
18
  steps:
19
19
  - uses: actions/checkout@v3
20
+ - uses: actions/setup-node@v3
20
21
  with:
21
- fetch-depth: 0
22
+ node-version: 18
23
+ cache: 'npm'
22
24
  - run: npm ci
23
25
  - run: npm run lint
24
26
  - run: npm test
27
+
28
+ - run: npm run build
29
+
30
+ - name: Read an issue content
31
+ id: read_issue
32
+ run: |
33
+ echo "body<<EOF" >> $GITHUB_OUTPUT
34
+ cat ./test/test-issue-3.md >> $GITHUB_OUTPUT
35
+ echo "EOF" >> $GITHUB_OUTPUT
36
+ - name: Issue Forms Body Parser With Provided Body
37
+ id: parse_with_body
38
+ uses: ./
39
+ with:
40
+ body: ${{ steps.read_issue.outputs.body }}
41
+
42
+ - name: Test input body parsed
43
+ run: |
44
+ expected="Event Description"
45
+ title=$(echo ${{ toJSON(steps.parse_with_body.outputs.data) }} | jq -r '.["event-description"].title')
46
+ if [[ $title != $expected ]]; then
47
+ echo "Title \"${title}\" does not match \"${expected}\""
48
+ exit 1
49
+ fi
@@ -0,0 +1 @@
1
+ {"parent":null,"pid":1827,"argv":["/opt/hostedtoolcache/node/18.13.0/x64/bin/node","/home/runner/work/issue-forms-body-parser/issue-forms-body-parser/node_modules/.bin/tap","--node-arg=--experimental-json-modules","--test-env=GITHUB_REPOSITORY=zentered/issue-forms-body-parser-test","-J","test/parse-issue.test.js"],"execArgv":[],"cwd":"/home/runner/work/issue-forms-body-parser/issue-forms-body-parser","time":1673864522799,"ppid":1816,"coverageFilename":"/home/runner/work/issue-forms-body-parser/issue-forms-body-parser/.nyc_output/857f5608-b83f-4630-842c-ac5e8a908fab.json","externalId":"","uuid":"857f5608-b83f-4630-842c-ac5e8a908fab","files":[]}
@@ -0,0 +1 @@
1
+ {"parent":"857f5608-b83f-4630-842c-ac5e8a908fab","pid":1838,"argv":["/opt/hostedtoolcache/node/18.13.0/x64/bin/node","/home/runner/work/issue-forms-body-parser/issue-forms-body-parser/test/parse-issue.test.js"],"execArgv":["--experimental-json-modules"],"cwd":"/home/runner/work/issue-forms-body-parser/issue-forms-body-parser","time":1673864523155,"ppid":1827,"coverageFilename":"/home/runner/work/issue-forms-body-parser/issue-forms-body-parser/.nyc_output/bf35b181-ad33-4747-963f-70af2a03dbb0.json","externalId":"test/parse-issue.test.js","uuid":"bf35b181-ad33-4747-963f-70af2a03dbb0","files":[]}
@@ -1 +1 @@
1
- {"processes":{"488cf9e0-2479-4d98-9daa-e56e51a96d7f":{"parent":null,"children":["506035e5-5150-4257-b8c2-9b0d5c9c3315"]},"506035e5-5150-4257-b8c2-9b0d5c9c3315":{"parent":"488cf9e0-2479-4d98-9daa-e56e51a96d7f","externalId":"test/parse-issue.test.js","children":[]}},"files":{},"externalIds":{"test/parse-issue.test.js":{"root":"506035e5-5150-4257-b8c2-9b0d5c9c3315","children":[]}}}
1
+ {"processes":{"857f5608-b83f-4630-842c-ac5e8a908fab":{"parent":null,"children":["bf35b181-ad33-4747-963f-70af2a03dbb0"]},"bf35b181-ad33-4747-963f-70af2a03dbb0":{"parent":"857f5608-b83f-4630-842c-ac5e8a908fab","externalId":"test/parse-issue.test.js","children":[]}},"files":{},"externalIds":{"test/parse-issue.test.js":{"root":"bf35b181-ad33-4747-963f-70af2a03dbb0","children":[]}}}
@@ -0,0 +1,128 @@
1
+ # Contributor Covenant Code of Conduct
2
+
3
+ ## Our Pledge
4
+
5
+ We as members, contributors, and leaders pledge to make participation in our
6
+ community a harassment-free experience for everyone, regardless of age, body
7
+ size, visible or invisible disability, ethnicity, sex characteristics, gender
8
+ identity and expression, level of experience, education, socio-economic status,
9
+ nationality, personal appearance, race, religion, or sexual identity and
10
+ orientation.
11
+
12
+ We pledge to act and interact in ways that contribute to an open, welcoming,
13
+ diverse, inclusive, and healthy community.
14
+
15
+ ## Our Standards
16
+
17
+ Examples of behavior that contributes to a positive environment for our
18
+ community include:
19
+
20
+ - Demonstrating empathy and kindness toward other people
21
+ - Being respectful of differing opinions, viewpoints, and experiences
22
+ - Giving and gracefully accepting constructive feedback
23
+ - Accepting responsibility and apologizing to those affected by our mistakes,
24
+ and learning from the experience
25
+ - Focusing on what is best not just for us as individuals, but for the overall
26
+ community
27
+
28
+ Examples of unacceptable behavior include:
29
+
30
+ - The use of sexualized language or imagery, and sexual attention or advances of
31
+ any kind
32
+ - Trolling, insulting or derogatory comments, and personal or political attacks
33
+ - Public or private harassment
34
+ - Publishing others' private information, such as a physical or email address,
35
+ without their explicit permission
36
+ - Other conduct which could reasonably be considered inappropriate in a
37
+ professional setting
38
+
39
+ ## Enforcement Responsibilities
40
+
41
+ Community leaders are responsible for clarifying and enforcing our standards of
42
+ acceptable behavior and will take appropriate and fair corrective action in
43
+ response to any behavior that they deem inappropriate, threatening, offensive,
44
+ or harmful.
45
+
46
+ Community leaders have the right and responsibility to remove, edit, or reject
47
+ comments, commits, code, wiki edits, issues, and other contributions that are
48
+ not aligned to this Code of Conduct, and will communicate reasons for moderation
49
+ decisions when appropriate.
50
+
51
+ ## Scope
52
+
53
+ This Code of Conduct applies within all community spaces, and also applies when
54
+ an individual is officially representing the community in public spaces.
55
+ Examples of representing our community include using an official e-mail address,
56
+ posting via an official social media account, or acting as an appointed
57
+ representative at an online or offline event.
58
+
59
+ ## Enforcement
60
+
61
+ Instances of abusive, harassing, or otherwise unacceptable behavior may be
62
+ reported to the community leaders responsible for enforcement at
63
+ contact@zentered.co. All complaints will be reviewed and investigated promptly
64
+ and fairly.
65
+
66
+ All community leaders are obligated to respect the privacy and security of the
67
+ reporter of any incident.
68
+
69
+ ## Enforcement Guidelines
70
+
71
+ Community leaders will follow these Community Impact Guidelines in determining
72
+ the consequences for any action they deem in violation of this Code of Conduct:
73
+
74
+ ### 1. Correction
75
+
76
+ **Community Impact**: Use of inappropriate language or other behavior deemed
77
+ unprofessional or unwelcome in the community.
78
+
79
+ **Consequence**: A private, written warning from community leaders, providing
80
+ clarity around the nature of the violation and an explanation of why the
81
+ behavior was inappropriate. A public apology may be requested.
82
+
83
+ ### 2. Warning
84
+
85
+ **Community Impact**: A violation through a single incident or series of
86
+ actions.
87
+
88
+ **Consequence**: A warning with consequences for continued behavior. No
89
+ interaction with the people involved, including unsolicited interaction with
90
+ those enforcing the Code of Conduct, for a specified period of time. This
91
+ includes avoiding interactions in community spaces as well as external channels
92
+ like social media. Violating these terms may lead to a temporary or permanent
93
+ ban.
94
+
95
+ ### 3. Temporary Ban
96
+
97
+ **Community Impact**: A serious violation of community standards, including
98
+ sustained inappropriate behavior.
99
+
100
+ **Consequence**: A temporary ban from any sort of interaction or public
101
+ communication with the community for a specified period of time. No public or
102
+ private interaction with the people involved, including unsolicited interaction
103
+ with those enforcing the Code of Conduct, is allowed during this period.
104
+ Violating these terms may lead to a permanent ban.
105
+
106
+ ### 4. Permanent Ban
107
+
108
+ **Community Impact**: Demonstrating a pattern of violation of community
109
+ standards, including sustained inappropriate behavior, harassment of an
110
+ individual, or aggression toward or disparagement of classes of individuals.
111
+
112
+ **Consequence**: A permanent ban from any sort of public interaction within the
113
+ community.
114
+
115
+ ## Attribution
116
+
117
+ This Code of Conduct is adapted from the [Contributor Covenant][homepage],
118
+ version 2.0, available at
119
+ https://www.contributor-covenant.org/version/2/0/code_of_conduct.html.
120
+
121
+ Community Impact Guidelines were inspired by
122
+ [Mozilla's code of conduct enforcement ladder](https://github.com/mozilla/diversity).
123
+
124
+ [homepage]: https://www.contributor-covenant.org
125
+
126
+ For answers to common questions about this code of conduct, see the FAQ at
127
+ https://www.contributor-covenant.org/faq. Translations are available at
128
+ https://www.contributor-covenant.org/translations.
package/CONTRIBUTING.md CHANGED
@@ -1,11 +1,15 @@
1
1
  # How to contribute
2
2
 
3
- We'd love to accept your patches and contributions to this project. There are just a few small guidelines you need to follow.
3
+ We'd love to accept your patches and contributions to this project. There are
4
+ just a few small guidelines you need to follow.
4
5
 
5
6
  ## Code reviews
6
7
 
7
- All submissions require review. We use GitHub pull requests for this purpose. Consult [GitHub Help](https://help.github.com/articles/about-pull-requests/) for more information on using pull requests.
8
+ All submissions require review. We use GitHub pull requests for this purpose.
9
+ Consult [GitHub Help](https://help.github.com/articles/about-pull-requests/) for
10
+ more information on using pull requests.
8
11
 
9
12
  ## Style Guide
10
13
 
11
- This project provides a prettier configuration. All submitted PRs will be required to conform to this style guide before being merged.
14
+ This project provides a prettier configuration. All submitted PRs will be
15
+ required to conform to this style guide before being merged.
package/README.md CHANGED
@@ -117,7 +117,40 @@ jobs:
117
117
  steps:
118
118
  - name: Issue Forms Body Parser
119
119
  id: parse
120
- uses: zentered/issue-forms-body-parser@v1.4.3
120
+ uses: zentered/issue-forms-body-parser@v2.0.0
121
+ - run: echo "${{ JSON.stringify(steps.parse.outputs.data) }}"
122
+ ```
123
+
124
+ You can also provide a custom `body` input:
125
+
126
+ ```yml
127
+ name: Issue Forms Body Parser
128
+
129
+ on:
130
+ workflow_dispatch:
131
+ inputs:
132
+ issue_number:
133
+ type: string
134
+ required: true
135
+ env:
136
+ GH_TOKEN: ${{ github.token }}
137
+
138
+ jobs:
139
+ process:
140
+ runs-on: ubuntu-latest
141
+ steps:
142
+ - name: Fetch the issue
143
+ id: read_issue_body
144
+ run:
145
+ echo "body=$(gh issue view ${{ inputs.issue_number }} --repo ${{
146
+ github.repo }} --json body --jq '.body')" >> $GITHUB_OUTPUT
147
+
148
+ - name: Issue Forms Body Parser
149
+ id: parse
150
+ uses: zentered/issue-forms-body-parser@v2.0.0
151
+ with:
152
+ body: ${{ steps.read_issue_body.output.body }}
153
+
121
154
  - run: echo "${{ JSON.stringify(steps.parse.outputs.data) }}"
122
155
  ```
123
156
 
@@ -141,7 +174,7 @@ const issueData = await bodyParser(issue.body)
141
174
 
142
175
  You can use [act](https://github.com/nektos/act) to test this Action locally.
143
176
 
144
- `npm run build && act issue -e test/issue.json`
177
+ `npm run build && act issues -e test/issue.json`
145
178
 
146
179
  or run:
147
180
 
package/action.yml CHANGED
@@ -6,6 +6,9 @@ description:
6
6
  branding:
7
7
  color: blue
8
8
  icon: chevron-right
9
+ inputs:
10
+ body:
11
+ description: 'The body to parse.'
9
12
  outputs:
10
13
  data:
11
14
  description:
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@zentered/issue-forms-body-parser",
3
- "version": "1.5.1",
3
+ "version": "2.1.0",
4
4
  "private": false,
5
5
  "description": "Parser for GitHub Issue Form body, also available as GitHub Action",
6
6
  "keywords": [
@@ -25,6 +25,10 @@
25
25
  "name": "Patrick Heneise",
26
26
  "url": "https://zentered.co",
27
27
  "author": true
28
+ },
29
+ {
30
+ "name": "Benjamin Grandfond",
31
+ "url": "https://github.com/benja-M-1"
28
32
  }
29
33
  ],
30
34
  "type": "module",
@@ -39,9 +43,7 @@
39
43
  "license-checker": "license-checker --production --onlyAllow=\"MIT;ISC;BSD-3-Clause;BSD-2-Clause;Apache-2.0\"",
40
44
  "test": "tap --node-arg=--experimental-json-modules --test-env=GITHUB_REPOSITORY=zentered/issue-forms-body-parser-test -J test/*.test.js",
41
45
  "test:report": "tap --test-env=GITHUB_REPOSITORY=zentered/issue-forms-body-parser-test -J test/*.test.js --cov",
42
- "_postinstall": "husky install",
43
- "prepublishOnly": "pinst --disable",
44
- "postpublish": "pinst --enable"
46
+ "prepare": "is-ci || husky install"
45
47
  },
46
48
  "commitlint": {
47
49
  "extends": [
@@ -67,6 +69,7 @@
67
69
  "@sindresorhus/slugify": "^2.1.1",
68
70
  "date-fns": "^2.29.3",
69
71
  "date-fns-tz": "^1.3.7",
72
+ "is-ci": "^3.0.1",
70
73
  "remark-gfm": "^3.0.1",
71
74
  "remark-parse": "^10.0.1",
72
75
  "remark-stringify": "^10.0.2",
@@ -74,19 +77,19 @@
74
77
  "unified": "^10.1.2"
75
78
  },
76
79
  "devDependencies": {
77
- "@commitlint/config-conventional": "^17.1.0",
78
- "@vercel/ncc": "^0.34.0",
79
- "commitlint": "^17.1.2",
80
- "eslint": "^8.25.0",
80
+ "@commitlint/config-conventional": "^17.4.2",
81
+ "@vercel/ncc": "^0.36.0",
82
+ "commitlint": "^17.4.2",
83
+ "eslint": "^8.32.0",
81
84
  "eslint-plugin-json": "^3.1.0",
82
85
  "eslint-plugin-node": "^11.1.0",
83
- "husky": "^8.0.1",
86
+ "husky": "^8.0.3",
84
87
  "license-checker": "^25.0.1",
85
88
  "microbundle": "^0.15.1",
86
89
  "npm-run-all": "^4.1.5",
87
90
  "pinst": "^3.0.0",
88
- "prettier": "^2.7.1",
89
- "tap": "^16.3.0"
91
+ "prettier": "^2.8.3",
92
+ "tap": "^16.3.4"
90
93
  },
91
94
  "src": "src/parse.js"
92
95
  }
package/pkg/parse.cjs CHANGED
@@ -1,2 +1,2 @@
1
- var e=require("unified"),n=require("remark-parse"),t=require("remark-gfm"),r=require("@sindresorhus/slugify"),i=require("remark-stringify"),o=require("strip-final-newline"),u=require("date-fns"),a=require("date-fns-tz/esm");function f(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var l=/*#__PURE__*/f(n),c=/*#__PURE__*/f(t),d=/*#__PURE__*/f(r),h=/*#__PURE__*/f(i),s=/*#__PURE__*/f(o);function y(e,n){(null==n||n>e.length)&&(n=e.length);for(var t=0,r=new Array(n);t<n;t++)r[t]=e[t];return r}var v=["yyyy-MM-dd","dd/MM/yyyy","dd/MM/yy","dd-MM-yyyy","dd-MM-yy","dd.MM.yyyy","dd.MM.yy"],m=["HH:mm","HH.mm","hh:mm a","hh:mm A"],p=function e(n){return n.children.map(function(t){var r={};return"list"===t.type?e(n):"listItem"===t.type?(r.checked=t.checked,t.children.map(function(e){if("paragraph"===e.type)return r.text=e.children.map(function(e){return"link"===e.type?e.children[0].value:e.value}).filter(function(e){return!!e}).join(""),r}).filter(function(e){return!!e})):void 0}).filter(function(e){return!!e})};function g(e,n,t){if(!e.s){if(t instanceof b){if(!t.s)return void(t.o=g.bind(null,e,n));1&n&&(n=t.s),t=t.v}if(t&&t.then)return void t.then(g.bind(null,e,n),g.bind(null,e,2));e.s=n,e.v=t;var r=e.o;r&&r(e)}}const b=/*#__PURE__*/function(){function e(){}return e.prototype.then=function(n,t){const r=new e,i=this.s;if(i){const e=1&i?n:t;if(e){try{g(r,1,e(this.v))}catch(e){g(r,2,e)}return r}return this}return this.o=function(e){try{const i=e.v;1&e.s?g(r,1,n?n(i):i):t?g(r,1,t(i)):g(r,2,i)}catch(e){g(r,2,e)}},r},e}();function M(e){return e instanceof b&&1&e.s}module.exports=function(n){try{var t,r,i,o,f,x,w,T,k,q,I,O,j;return Promise.resolve(e.unified().use(l.default).use(c.default).parse(n)).then(function(n){function l(){for(I in A)(j=(O=A[I]).content.filter(Boolean))&&j.length>0&&(1===j.length&&(O.text=j[0]),O.text=j.join("\n\n")),O.content=j;return A}if(!n)return[];var A={},U=null;t=function(e,n){var t="undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(t)return(t=t.call(e)).next.bind(t);if(Array.isArray(e)||(t=function(e,n){if(e){if("string"==typeof e)return y(e,n);var t=Object.prototype.toString.call(e).slice(8,-1);return"Object"===t&&e.constructor&&(t=e.constructor.name),"Map"===t||"Set"===t?Array.from(e):"Arguments"===t||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t)?y(e,n):void 0}}(e))){t&&(e=t);var r=0;return function(){return r>=e.length?{done:!0}:{done:!1,value:e[r++]}}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}(n.children);var H=function(e,n,t){for(var r;;){var i=e();if(M(i)&&(i=i.v),!i)return o;if(i.then){r=0;break}var o=t();if(o&&o.then){if(!M(o)){r=1;break}o=o.s}}var u=new b,a=g.bind(null,u,2);return(0===r?i.then(l):1===r?o.then(f):(void 0).then(function(){(i=e())?i.then?i.then(l).then(void 0,a):l(i):g(u,1,o)})).then(void 0,a),u;function f(n){o=n;do{if(!(i=e())||M(i)&&!i.v)return void g(u,1,o);if(i.then)return void i.then(l).then(void 0,a);M(o=t())&&(o=o.v)}while(!o||!o.then);o.then(f).then(void 0,a)}function l(e){e?(o=t())&&o.then?o.then(f).then(void 0,a):f(o):g(u,1,o)}}(function(){return!(r=t()).done},0,function(){return i=r.value,Promise.resolve(e.unified().use(c.default).use(h.default).stringify(i)).then(function(e){var n,t;(o=s.default(e)).indexOf("\\_")>-1&&(o=o.replace(/\\_/g,"_")),"heading"===i.type&&3===i.depth?(U=d.default(i.children[0].value),A[U]={title:i.children[0].value,content:[]}):"paragraph"===i.type&&U?(f=A[U],n=o,t=v.map(function(e){return u.isMatch(n,e)}),x=t.indexOf(!0)>-1?a.zonedTimeToUtc(u.parse(n,v[t.indexOf(!0)],new Date),"UTC").toJSON().split("T")[0]:null,w=function(e){var n=m.map(function(n){return u.isMatch(e,n)});if(n.indexOf(!0)>-1){var t=a.zonedTimeToUtc(u.parse(e,m[n.indexOf(!0)],new Date),"UTC");return a.formatInTimeZone(t,"UTC","HH:mm")}return null}(o),T=function(e){var n=!1,t={hours:0,minutes:0},r=new RegExp(/([0-9]+)h([0-9]+)m/),i=new RegExp(/([0-9]+)h/);if(e.match(r)){n=!0;var o=e.match(r),u=o[2];t.hours=parseInt(o[1]),t.minutes=parseInt(u)}else if(e.match(i)){n=!0;var a=e.match(i);t.hours=parseInt(a[1]),t.minutes=0}return n?t:null}(o),x&&(f.date=x),w&&(f.time=w),T&&(f.duration=T),f.content.push(o)):"list"===i.type?((k=A[U]).text=o,k.list=p(i).flat()):"html"===i.type?A[U].content.push(i.html):"code"===i.type?((q=A[U]).lang=i.lang,q.text=o):"heading"===i.type&&i.depth>3?A[U].content.push(i.children[0].value):process.env.DEBUG&&(console.log("unhandled token type"),console.log(i))})});return H&&H.then?H.then(l):l()})}catch(e){return Promise.reject(e)}};
1
+ var e=require("unified"),n=require("remark-parse"),t=require("remark-gfm"),r=require("@sindresorhus/slugify"),i=require("remark-stringify"),u=require("strip-final-newline"),o=require("date-fns"),a=require("date-fns-tz/esm");function f(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var l=/*#__PURE__*/f(n),c=/*#__PURE__*/f(t),d=/*#__PURE__*/f(r),h=/*#__PURE__*/f(i),s=/*#__PURE__*/f(u);function y(e,n){(null==n||n>e.length)&&(n=e.length);for(var t=0,r=new Array(n);t<n;t++)r[t]=e[t];return r}var v=["yyyy-MM-dd","dd/MM/yyyy","dd/MM/yy","dd-MM-yyyy","dd-MM-yy","dd.MM.yyyy","dd.MM.yy"],m=["HH:mm","HH.mm","hh:mm a","hh:mm A"],p=function e(n){return n.children.map(function(t){var r={};return"list"===t.type?e(n):"listItem"===t.type?(r.checked=t.checked,t.children.map(function(e){if("paragraph"===e.type)return r.text=e.children.map(function(e){return"link"===e.type?(r.link=e.url,"["+e.children[0].value+"]("+e.url+")"):e.value}).filter(function(e){return!!e}).join(""),r}).filter(function(e){return!!e})):void 0}).filter(function(e){return!!e})};function g(e,n,t){if(!e.s){if(t instanceof b){if(!t.s)return void(t.o=g.bind(null,e,n));1&n&&(n=t.s),t=t.v}if(t&&t.then)return void t.then(g.bind(null,e,n),g.bind(null,e,2));e.s=n,e.v=t;var r=e.o;r&&r(e)}}const b=/*#__PURE__*/function(){function e(){}return e.prototype.then=function(n,t){const r=new e,i=this.s;if(i){const e=1&i?n:t;if(e){try{g(r,1,e(this.v))}catch(e){g(r,2,e)}return r}return this}return this.o=function(e){try{const i=e.v;1&e.s?g(r,1,n?n(i):i):t?g(r,1,t(i)):g(r,2,i)}catch(e){g(r,2,e)}},r},e}();function M(e){return e instanceof b&&1&e.s}module.exports=function(n){try{var t,r,i,u,f,x,w,k,T,q,I,O,j;return Promise.resolve(e.unified().use(l.default).use(c.default).parse(n)).then(function(n){function l(){for(I in A)(j=(O=A[I]).content.filter(Boolean))&&j.length>0&&(1===j.length&&(O.text=j[0]),O.text=j.join("\n\n")),O.content=j;return A}if(!n)return[];var A={},U=null;t=function(e,n){var t="undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(t)return(t=t.call(e)).next.bind(t);if(Array.isArray(e)||(t=function(e,n){if(e){if("string"==typeof e)return y(e,n);var t=Object.prototype.toString.call(e).slice(8,-1);return"Object"===t&&e.constructor&&(t=e.constructor.name),"Map"===t||"Set"===t?Array.from(e):"Arguments"===t||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t)?y(e,n):void 0}}(e))){t&&(e=t);var r=0;return function(){return r>=e.length?{done:!0}:{done:!1,value:e[r++]}}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}(n.children);var H=function(e,n,t){for(var r;;){var i=e();if(M(i)&&(i=i.v),!i)return u;if(i.then){r=0;break}var u=t();if(u&&u.then){if(!M(u)){r=1;break}u=u.s}}var o=new b,a=g.bind(null,o,2);return(0===r?i.then(l):1===r?u.then(f):(void 0).then(function(){(i=e())?i.then?i.then(l).then(void 0,a):l(i):g(o,1,u)})).then(void 0,a),o;function f(n){u=n;do{if(!(i=e())||M(i)&&!i.v)return void g(o,1,u);if(i.then)return void i.then(l).then(void 0,a);M(u=t())&&(u=u.v)}while(!u||!u.then);u.then(f).then(void 0,a)}function l(e){e?(u=t())&&u.then?u.then(f).then(void 0,a):f(u):g(o,1,u)}}(function(){return!(r=t()).done},0,function(){return i=r.value,Promise.resolve(e.unified().use(c.default).use(h.default).stringify(i)).then(function(e){var n,t;(u=s.default(e)).indexOf("\\_")>-1&&(u=u.replace(/\\_/g,"_")),"heading"===i.type?(U=d.default(i.children[0].value),A[U]={title:i.children[0].value,heading:i.depth,content:[]}):"paragraph"===i.type&&U?(f=A[U],n=u,t=v.map(function(e){return o.isMatch(n,e)}),x=t.indexOf(!0)>-1?a.zonedTimeToUtc(o.parse(n,v[t.indexOf(!0)],new Date),"UTC").toJSON().split("T")[0]:null,w=function(e){var n=m.map(function(n){return o.isMatch(e,n)});if(n.indexOf(!0)>-1){var t=a.zonedTimeToUtc(o.parse(e,m[n.indexOf(!0)],new Date),"UTC");return a.formatInTimeZone(t,"UTC","HH:mm")}return null}(u),k=function(e){var n=!1,t={hours:0,minutes:0},r=new RegExp(/([0-9]+)h([0-9]+)m/),i=new RegExp(/([0-9]+)h/);if(e.match(r)){n=!0;var u=e.match(r),o=u[2];t.hours=parseInt(u[1]),t.minutes=parseInt(o)}else if(e.match(i)){n=!0;var a=e.match(i);t.hours=parseInt(a[1]),t.minutes=0}return n?t:null}(u),x&&(f.date=x),w&&(f.time=w),k&&(f.duration=k),f.content.push(u)):"list"===i.type?((T=A[U]).text=u,T.list=p(i).flat()):"html"===i.type?A[U].content.push(i.html):"code"===i.type?((q=A[U]).lang=i.lang,q.text=u):process.env.DEBUG&&(console.log("unhandled token type"),console.log(i))})});return H&&H.then?H.then(l):l()})}catch(e){return Promise.reject(e)}};
2
2
  //# sourceMappingURL=parse.cjs.map
package/pkg/parse.cjs.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"parse.cjs","sources":["../src/parsers/date.js","../src/parsers/time.js","../src/parsers/index.js","../src/parsers/list.js","../src/parse.js","../src/parsers/duration.js"],"sourcesContent":["'use strict'\n\nimport { parse, isMatch } from 'date-fns'\nimport { zonedTimeToUtc } from 'date-fns-tz/esm'\n\nconst loc = 'UTC'\nconst commonDateFormats = [\n 'yyyy-MM-dd',\n 'dd/MM/yyyy',\n 'dd/MM/yy',\n 'dd-MM-yyyy',\n 'dd-MM-yy',\n 'dd.MM.yyyy',\n 'dd.MM.yy'\n]\n\nexport default function parseDate(text) {\n const match = commonDateFormats.map((format) => {\n return isMatch(text, format)\n })\n if (match.indexOf(true) > -1) {\n const date = zonedTimeToUtc(\n parse(text, commonDateFormats[match.indexOf(true)], new Date()),\n loc\n ).toJSON()\n return date.split('T')[0]\n } else {\n return null\n }\n}\n","'use strict'\n\nimport { parse, isMatch } from 'date-fns'\nimport { zonedTimeToUtc, formatInTimeZone } from 'date-fns-tz/esm'\n\nconst loc = 'UTC'\nconst commonTimeFormats = ['HH:mm', 'HH.mm', 'hh:mm a', 'hh:mm A']\n\nexport default function parseTime(text) {\n const match = commonTimeFormats.map((format) => {\n return isMatch(text, format)\n })\n if (match.indexOf(true) > -1) {\n const time = zonedTimeToUtc(\n parse(text, commonTimeFormats[match.indexOf(true)], new Date()),\n loc\n )\n return formatInTimeZone(time, loc, 'HH:mm')\n } else {\n return null\n }\n}\n","'use strict'\n\nimport date from './date.js'\nimport time from './time.js'\nimport duration from './duration.js'\nimport list from './list.js'\n\nexport const parseDate = date\nexport const parseTime = time\nexport const parseDuration = duration\nexport const parseList = list\n","'use strict'\n\nexport default function parseList(list) {\n return list.children\n .map((item) => {\n const listItem = {}\n if (item.type === 'list') {\n return parseList(list)\n } else if (item.type === 'listItem') {\n listItem.checked = item.checked\n return item.children\n .map((child) => {\n if (child.type === 'paragraph') {\n listItem.text = child.children\n .map((c) => {\n if (c.type === 'link') {\n return c.children[0].value\n } else {\n return c.value\n }\n })\n .filter((x) => !!x)\n .join('')\n return listItem\n }\n })\n .filter((x) => !!x)\n }\n })\n .filter((x) => !!x)\n}\n","'use strict'\n\nimport { unified } from 'unified'\nimport remarkParse from 'remark-parse'\nimport remarkGfm from 'remark-gfm'\nimport slugify from '@sindresorhus/slugify'\nimport remarkStringify from 'remark-stringify'\nimport stripFinalNewline from 'strip-final-newline'\n\nimport {\n parseDate,\n parseTime,\n parseDuration,\n parseList\n} from './parsers/index.js'\n\nexport default async function parseMD(body) {\n const tokens = await unified().use(remarkParse).use(remarkGfm).parse(body)\n if (!tokens) {\n return []\n }\n\n const structuredResponse = {}\n let currentHeading = null\n for (const token of tokens.children) {\n const text = await unified()\n .use(remarkGfm)\n .use(remarkStringify)\n .stringify(token)\n let cleanText = stripFinalNewline(text)\n\n // remove `\\\\_`\n if (cleanText.indexOf('\\\\_') > -1) {\n cleanText = cleanText.replace(/\\\\_/g, '_')\n }\n\n // issue forms uses h3 as a heading\n if (token.type === 'heading' && token.depth === 3) {\n currentHeading = slugify(token.children[0].value)\n structuredResponse[currentHeading] = {\n title: token.children[0].value,\n content: []\n }\n } else if (token.type === 'paragraph' && currentHeading) {\n const obj = structuredResponse[currentHeading]\n\n const date = parseDate(cleanText)\n const time = parseTime(cleanText)\n const duration = parseDuration(cleanText)\n\n if (date) {\n obj.date = date\n }\n\n if (time) {\n obj.time = time\n }\n\n if (duration) {\n obj.duration = duration\n }\n\n obj.content.push(cleanText)\n } else if (token.type === 'list') {\n const obj = structuredResponse[currentHeading]\n obj.text = cleanText\n obj.list = parseList(token).flat()\n } else if (token.type === 'html') {\n const obj = structuredResponse[currentHeading]\n obj.content.push(token.html)\n } else if (token.type === 'code') {\n const obj = structuredResponse[currentHeading]\n obj.lang = token.lang\n obj.text = cleanText\n } else if (token.type === 'heading' && token.depth > 3) {\n const obj = structuredResponse[currentHeading]\n obj.content.push(token.children[0].value)\n } else {\n if(process.env.DEBUG){\n console.log('unhandled token type')\n console.log(token) \n }\n }\n }\n\n for (const key in structuredResponse) {\n const token = structuredResponse[key]\n const content = token.content.filter(Boolean)\n if (content && content.length > 0) {\n if (content.length === 1) {\n token.text = content[0]\n }\n token.text = content.join('\\n\\n')\n }\n token.content = content\n }\n\n return structuredResponse\n}\n","'use strict'\n\nexport default function parseDuration(text) {\n let matched = false\n const duration = {\n hours: 0,\n minutes: 0\n }\n\n const hoursAndMinutes = new RegExp(/([0-9]+)h([0-9]+)m/)\n const hours = new RegExp(/([0-9]+)h/)\n\n if (text.match(hoursAndMinutes)) {\n matched = true\n const [, h, m] = text.match(hoursAndMinutes)\n duration.hours = parseInt(h)\n duration.minutes = parseInt(m)\n } else if (text.match(hours)) {\n matched = true\n const [, h] = text.match(hours)\n duration.hours = parseInt(h)\n duration.minutes = 0\n }\n\n if (matched) {\n return duration\n } else {\n return null\n }\n}\n"],"names":["commonDateFormats","commonTimeFormats","parseList","list","children","map","item","listItem","type","checked","child","text","c","value","filter","x","join","_settle","pact","state","s","_Pact","o","bind","v","then","observer","prototype","onFulfilled","onRejected","result","this","callback","e","_this","_isSettledPact","thenable","body","token","cleanText","obj","date","time","duration","key","content","unified","use","remarkParse","remarkGfm","parse","tokens","_temp2","structuredResponse","Boolean","length","currentHeading","_iterator","_createForOfIteratorHelperLoose","_temp","test","update","stage","shouldContinue","reject","_resumeAfterTest","_resumeAfterBody","updateValue","_for","_step","done","Promise","resolve","remarkStringify","stringify","_unified$use$use$stri","match","stripFinalNewline","indexOf","replace","depth","slugify","title","format","isMatch","zonedTimeToUtc","Date","toJSON","split","parseTime","formatInTimeZone","matched","hours","minutes","hoursAndMinutes","RegExp","_text$match","m","parseInt","parseDuration","push","flat","html","lang","process","env","DEBUG","console","log"],"mappings":"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"}
1
+ {"version":3,"file":"parse.cjs","sources":["../src/parsers/date.js","../src/parsers/time.js","../src/parsers/index.js","../src/parsers/list.js","../src/parse.js","../src/parsers/duration.js"],"sourcesContent":["'use strict'\n\nimport { parse, isMatch } from 'date-fns'\nimport { zonedTimeToUtc } from 'date-fns-tz/esm'\n\nconst loc = 'UTC'\nconst commonDateFormats = [\n 'yyyy-MM-dd',\n 'dd/MM/yyyy',\n 'dd/MM/yy',\n 'dd-MM-yyyy',\n 'dd-MM-yy',\n 'dd.MM.yyyy',\n 'dd.MM.yy'\n]\n\nexport default function parseDate(text) {\n const match = commonDateFormats.map((format) => {\n return isMatch(text, format)\n })\n if (match.indexOf(true) > -1) {\n const date = zonedTimeToUtc(\n parse(text, commonDateFormats[match.indexOf(true)], new Date()),\n loc\n ).toJSON()\n return date.split('T')[0]\n } else {\n return null\n }\n}\n","'use strict'\n\nimport { parse, isMatch } from 'date-fns'\nimport { zonedTimeToUtc, formatInTimeZone } from 'date-fns-tz/esm'\n\nconst loc = 'UTC'\nconst commonTimeFormats = ['HH:mm', 'HH.mm', 'hh:mm a', 'hh:mm A']\n\nexport default function parseTime(text) {\n const match = commonTimeFormats.map((format) => {\n return isMatch(text, format)\n })\n if (match.indexOf(true) > -1) {\n const time = zonedTimeToUtc(\n parse(text, commonTimeFormats[match.indexOf(true)], new Date()),\n loc\n )\n return formatInTimeZone(time, loc, 'HH:mm')\n } else {\n return null\n }\n}\n","'use strict'\n\nimport date from './date.js'\nimport time from './time.js'\nimport duration from './duration.js'\nimport list from './list.js'\n\nexport const parseDate = date\nexport const parseTime = time\nexport const parseDuration = duration\nexport const parseList = list\n","'use strict'\n\nexport default function parseList(list) {\n return list.children\n .map((item) => {\n const listItem = {}\n if (item.type === 'list') {\n return parseList(list)\n } else if (item.type === 'listItem') {\n listItem.checked = item.checked\n return item.children\n .map((child) => {\n if (child.type === 'paragraph') {\n listItem.text = child.children\n .map((c) => {\n if (c.type === 'link') {\n listItem.link = c.url\n return `[${c.children[0].value}](${c.url})`\n } else {\n return c.value\n }\n })\n .filter((x) => !!x)\n .join('')\n return listItem\n }\n })\n .filter((x) => !!x)\n }\n })\n .filter((x) => !!x)\n}\n","'use strict'\n\nimport { unified } from 'unified'\nimport remarkParse from 'remark-parse'\nimport remarkGfm from 'remark-gfm'\nimport slugify from '@sindresorhus/slugify'\nimport remarkStringify from 'remark-stringify'\nimport stripFinalNewline from 'strip-final-newline'\n\nimport {\n parseDate,\n parseTime,\n parseDuration,\n parseList\n} from './parsers/index.js'\n\nexport default async function parseMD(body) {\n const tokens = await unified().use(remarkParse).use(remarkGfm).parse(body)\n if (!tokens) {\n return []\n }\n\n const structuredResponse = {}\n let currentHeading = null\n for (const token of tokens.children) {\n const text = await unified()\n .use(remarkGfm)\n .use(remarkStringify)\n .stringify(token)\n let cleanText = stripFinalNewline(text)\n\n // remove `\\\\_`\n if (cleanText.indexOf('\\\\_') > -1) {\n cleanText = cleanText.replace(/\\\\_/g, '_')\n }\n\n // issue forms uses h3 as a heading\n if (token.type === 'heading') {\n currentHeading = slugify(token.children[0].value)\n structuredResponse[currentHeading] = {\n title: token.children[0].value,\n heading: token.depth,\n content: []\n }\n } else if (token.type === 'paragraph' && currentHeading) {\n const obj = structuredResponse[currentHeading]\n\n const date = parseDate(cleanText)\n const time = parseTime(cleanText)\n const duration = parseDuration(cleanText)\n\n if (date) {\n obj.date = date\n }\n\n if (time) {\n obj.time = time\n }\n\n if (duration) {\n obj.duration = duration\n }\n\n obj.content.push(cleanText)\n } else if (token.type === 'list') {\n const obj = structuredResponse[currentHeading]\n obj.text = cleanText\n obj.list = parseList(token).flat()\n } else if (token.type === 'html') {\n const obj = structuredResponse[currentHeading]\n obj.content.push(token.html)\n } else if (token.type === 'code') {\n const obj = structuredResponse[currentHeading]\n obj.lang = token.lang\n obj.text = cleanText\n } else {\n if (process.env.DEBUG) {\n console.log('unhandled token type')\n console.log(token)\n }\n }\n }\n\n for (const key in structuredResponse) {\n const token = structuredResponse[key]\n const content = token.content.filter(Boolean)\n if (content && content.length > 0) {\n if (content.length === 1) {\n token.text = content[0]\n }\n token.text = content.join('\\n\\n')\n }\n token.content = content\n }\n\n return structuredResponse\n}\n","'use strict'\n\nexport default function parseDuration(text) {\n let matched = false\n const duration = {\n hours: 0,\n minutes: 0\n }\n\n const hoursAndMinutes = new RegExp(/([0-9]+)h([0-9]+)m/)\n const hours = new RegExp(/([0-9]+)h/)\n\n if (text.match(hoursAndMinutes)) {\n matched = true\n const [, h, m] = text.match(hoursAndMinutes)\n duration.hours = parseInt(h)\n duration.minutes = parseInt(m)\n } else if (text.match(hours)) {\n matched = true\n const [, h] = text.match(hours)\n duration.hours = parseInt(h)\n duration.minutes = 0\n }\n\n if (matched) {\n return duration\n } else {\n return null\n }\n}\n"],"names":["commonDateFormats","commonTimeFormats","parseList","list","children","map","item","listItem","type","checked","child","text","c","link","url","value","filter","x","join","_settle","pact","state","s","_Pact","o","bind","v","then","observer","prototype","onFulfilled","onRejected","result","this","callback","e","_this","thenable","body","token","cleanText","obj","date","time","duration","key","content","unified","use","remarkParse","remarkGfm","parse","tokens","_temp2","structuredResponse","Boolean","length","currentHeading","_iterator","test","update","stage","shouldContinue","_isSettledPact","reject","_resumeAfterTest","_resumeAfterBody","updateValue","remarkStringify","stringify","match","stripFinalNewline","indexOf","replace","slugify","title","heading","depth","format","isMatch","zonedTimeToUtc","Date","toJSON","split","parseTime","formatInTimeZone","matched","hours","minutes","hoursAndMinutes","RegExp","_text$match","m","parseInt","parseDuration","push","flat","html","lang","process","env","DEBUG","console","log"],"mappings":"0fAKA,IACMA,EAAoB,CACxB,aACA,aACA,WACA,aACA,WACA,aACA,YCPIC,EAAoB,CAAC,QAAS,QAAS,UAAW,WCI3CC,ECRWA,SAAAA,EAAUC,GAChC,OAAOA,EAAKC,SACTC,IAAI,SAACC,GACJ,IAAMC,EAAW,CAAjB,EACA,MAAkB,SAAdD,EAAKE,KACAN,EAAUC,GACM,aAAdG,EAAKE,MACdD,EAASE,QAAUH,EAAKG,QACjBH,EAAKF,SACTC,IAAI,SAACK,GACJ,GAAmB,cAAfA,EAAMF,KAYR,OAXAD,EAASI,KAAOD,EAAMN,SACnBC,IAAI,SAACO,GACJ,MAAe,SAAXA,EAAEJ,MACJD,EAASM,KAAOD,EAAEE,IAClB,IAAWF,EAAER,SAAS,GAAGW,MAAzB,KAAmCH,EAAEE,SAE9BF,EAAEG,KAEZ,GACAC,OAAO,SAACC,GAAD,QAASA,CAAT,GACPC,KAAK,IACDX,CAEV,GACAS,OAAO,SAACC,GAAM,QAAEA,CAAT,SAnBDX,CAqBZ,GACAU,OAAO,SAACC,GAAD,QAASA,CAAT,EACX,ECQM,SAASE,EAAQC,EAAMC,EAAON,GACpC,IAAKK,EAAKE,EAAG,CACZ,GAAIP,aAAiBQ,EAAO,CAC3B,IAAIR,EAAMO,EAOT,YADAP,EAAMS,EAAIL,EAAQM,KAAK,KAAML,EAAMC,IALvB,EAARA,IACHA,EAAQN,EAAMO,GAEfP,EAAQA,EAAMW,CAKf,CACD,GAAIX,GAASA,EAAMY,KAElB,YADAZ,EAAMY,KAAKR,EAAQM,KAAK,KAAML,EAAMC,GAAQF,EAAQM,KAAK,KAAML,EAAM,IAGtEA,EAAKE,EAAID,EACTD,EAAKM,EAAIX,EACT,IAAMa,EAAWR,EAAKI,EAClBI,GACHA,EAASR,EAEV,CACD,CA9DM,MAAMG,eAAsB,WAClC,SAAAA,IACA,CAgCA,OAhCAA,EAAMM,UAAUF,KAAO,SAASG,EAAaC,GAC5C,MAAMC,EAAS,IAAAT,EACTF,EAAQY,KAAKX,EACnB,GAAID,EAAO,CACV,MAAMa,EAAmB,EAARb,EAAYS,EAAcC,EAC3C,GAAIG,EAAU,CACb,IACCf,EAAQa,EAAQ,EAAGE,EAASD,KAAKP,GAGjC,CAFC,MAAOS,GACRhB,EAAQa,EAAQ,EAAGG,EACnB,CACD,OAAOH,CACP,CACA,OACAC,IACD,CAeD,OAdAA,KAAKT,EAAI,SAASY,GACjB,IACC,MAAMrB,EAAQqB,EAAMV,EACN,EAAVU,EAAMd,EACTH,EAAQa,EAAQ,EAAGF,EAAcA,EAAYf,GAASA,GAC5CgB,EACVZ,EAAQa,EAAQ,EAAGD,EAAWhB,IAE9BI,EAAQa,EAAQ,EAAGjB,EAIpB,CAFC,MAAOoB,GACRhB,EAAQa,EAAQ,EAAGG,EACnB,CACD,EACMH,CACP,EAEDT,CAAA,CAnCkC,GAgE5B,WAAwBc,GAC9B,OAAOA,aAAQd,GAAkC,EAAbc,EAASf,CAC7C,yBAnDqCgB,OAQzBC,IAAAA,EAAAA,EAAAA,EAKLC,EAgBIC,EAEAC,EACAC,EACAC,EAgBAH,EAOAA,EAWCI,EACHN,EACAO,EApEaC,OAAAA,QAAAA,QAAAA,EAAAA,UAAUC,IAAIC,EAAAA,SAAaD,IAAIE,EAAAA,SAAWC,MAAMb,IAA/Dc,KAAAA,SAAAA,GAkEN,SAAAC,IAAA,IAAWR,KAAOS,GAEVR,GADAP,EAAQe,EAAmBT,IACXC,QAAQ9B,OAAOuC,WACtBT,EAAQU,OAAS,IACP,IAAnBV,EAAQU,SACVjB,EAAM5B,KAAOmC,EAAQ,IAEvBP,EAAM5B,KAAOmC,EAAQ5B,KAAK,SAE5BqB,EAAMO,QAAUA,EAGlB,OAAOQ,CA/EmC,CAE1C,IAAKF,EACH,MAAO,GAGT,IAAME,EAAqB,CAA3B,EACIG,EAAiB,KAPqBC,2qBAQtBN,CAAAA,EAAOhD,gBAuOtB,SAAcuD,EAAMC,EAAQtB,GAElC,IADA,IAAIuB,IACK,CACR,IAAIC,EAAiBH,IAIrB,GAHII,EAAeD,KAClBA,EAAiBA,EAAepC,IAE5BoC,EACJ,OAAO9B,EAER,GAAI8B,EAAenC,KAAM,CACxBkC,EAAQ,EACR,KACA,CACD,IAAI7B,EAASM,IACb,GAAIN,GAAUA,EAAOL,KAAM,CAC1B,IAAIoC,EAAe/B,GAEZ,CACN6B,EAAQ,EACR,KACA,CAJA7B,EAASA,EAAOV,CAKjB,CAQD,CACD,IAAIF,EAAO,IAAAG,EACPyC,EAAS7C,EAAQM,KAAK,KAAML,EAAM,GAEtC,OADW,IAAVyC,EAAcC,EAAenC,KAAKsC,GAA8B,IAAVJ,EAAc7B,EAAOL,KAAKuC,SAT3EC,GAS2GxC,KAwCjH,YACKmC,EAAiBH,KAChBG,EAAenC,KAClBmC,EAAenC,KAAKsC,GAAkBtC,UAAK,EAAQqC,GAEnDC,EAAiBH,GAGlB3C,EAAQC,EAAM,EAAGY,EAElB,IAlD0IL,UAAK,EAAQqC,GACjJ5C,EACP,SAAS8C,EAAiBnD,GACzBiB,EAASjB,EACT,EAAG,CASF,KADA+C,EAAiBH,MACOI,EAAeD,KAAoBA,EAAepC,EAEzE,YADAP,EAAQC,EAAM,EAAGY,GAGlB,GAAI8B,EAAenC,KAElB,YADAmC,EAAenC,KAAKsC,GAAkBtC,UAAK,EAAQqC,GAIhDD,EADJ/B,EAASM,OAERN,EAASA,EAAON,EAEjB,QAASM,IAAWA,EAAOL,MAC5BK,EAAOL,KAAKuC,GAAkBvC,UAAK,EAAQqC,EAC3C,CACD,SAASC,EAAiBH,GACrBA,GACH9B,EAASM,MACKN,EAAOL,KACpBK,EAAOL,KAAKuC,GAAkBvC,UAAK,EAAQqC,GAE3CE,EAAiBlC,GAGlBb,EAAQC,EAAM,EAAGY,EAElB,CAYD,+CA1TsBe,OADVR,EACUQ,EAAAA,MAAAA,QAAAA,QAAAA,EAAAA,UAChBC,IAAIE,EAAAA,SACJF,IAAIoB,EAAAA,SACJC,UAAU9B,IAHP5B,KAAAA,SAAAA,GJTK,IAAmBA,EAC1B2D,GIYA9B,EAAY+B,EAAAA,QAAZ/B,IAGUgC,QAAQ,QAAU,IAC9BhC,EAAYA,EAAUiC,QAAQ,OAAQ,MAIrB,YAAflC,EAAM/B,MACRiD,EAAiBiB,UAAQnC,EAAMnC,SAAS,GAAGW,OAC3CuC,EAAmBG,GAAkB,CACnCkB,MAAOpC,EAAMnC,SAAS,GAAGW,MACzB6D,QAASrC,EAAMsC,MACf/B,QAAS,KAEa,cAAfP,EAAM/B,MAAwBiD,GACjChB,EAAMa,EAAmBG,GJ7BH9C,EI+BL6B,EJ9BrB8B,EAAQtE,EAAkBK,IAAI,SAACyE,GACnC,OAAOC,EAAAA,QAAQpE,EAAMmE,EACtB,GI4BSpC,EJ3BN4B,EAAME,SAAQ,IAAS,EACZQ,EAAAA,eACX7B,EAAKA,MAACxC,EAAMX,EAAkBsE,EAAME,SAAQ,IAAQ,IAAIS,MAjBlD,OAmBNC,SACUC,MAAM,KAAK,QIuBfxC,EHxCYyC,SAAUzE,GAChC,IAAM2D,EAAQrE,EAAkBI,IAAI,SAACyE,GACnC,OAAOC,UAAQpE,EAAMmE,EACtB,GACD,GAAIR,EAAME,SAAQ,IAAS,EAAG,CAC5B,IAAM7B,EAAOqC,EAAAA,eACX7B,EAAKA,MAACxC,EAAMV,EAAkBqE,EAAME,SAAQ,IAAQ,IAAIS,MATlD,OAYR,OAAOI,EAAgBA,iBAAC1C,EAZhB,MAY2B,QACpC,CACC,OAAO,IAEV,CG2BkByC,CAAU5C,GACjBI,EC/CG,SAAuBjC,GACpC,IAAI2E,GAAU,EACR1C,EAAW,CACf2C,MAAO,EACPC,QAAS,GAGLC,EAAkB,IAAIC,OAAO,sBAC7BH,EAAQ,IAAIG,OAAO,aAEzB,GAAI/E,EAAK2D,MAAMmB,GAAkB,CAC/BH,GAAU,EACV,IAAAK,EAAiBhF,EAAK2D,MAAMmB,GAAhBG,EACZhD,EAAAA,GAAAA,EAAS2C,MAAQM,SADLD,EAAAA,IAEZhD,EAAS4C,QAAUK,SAASD,EAC7B,MAAUjF,GAAAA,EAAK2D,MAAMiB,GAAQ,CAC5BD,GAAU,EACV,IAAc3E,EAAAA,EAAK2D,MAAMiB,GACzB3C,EAAS2C,MAAQM,SAAjBjD,EAAAA,IACAA,EAAS4C,QAAU,CACpB,CAED,OAAIF,EACK1C,MAIV,CDoBsBkD,CAActD,GAE3BE,IACFD,EAAIC,KAAOA,GAGTC,IACFF,EAAIE,KAAOA,GAGTC,IACFH,EAAIG,SAAWA,GAGjBH,EAAIK,QAAQiD,KAAKvD,IACO,SAAfD,EAAM/B,OACTiC,EAAMa,EAAmBG,IAC3B9C,KAAO6B,EACXC,EAAItC,KAAOD,EAAUqC,GAAOyD,QACJ,SAAfzD,EAAM/B,KACH8C,EAAmBG,GAC3BX,QAAQiD,KAAKxD,EAAM0D,MACC,SAAf1D,EAAM/B,OACTiC,EAAMa,EAAmBG,IAC3ByC,KAAO3D,EAAM2D,KACjBzD,EAAI9B,KAAO6B,GAEP2D,QAAQC,IAAIC,QACdC,QAAQC,IAAI,wBACZD,QAAQC,IAAIhE,GAtDmB,EAyDpC"}
package/pkg/parse.js CHANGED
@@ -1,2 +1,2 @@
1
- import{unified as n}from"unified";import t from"remark-parse";import e from"remark-gfm";import r from"@sindresorhus/slugify";import i from"remark-stringify";import o from"strip-final-newline";import{isMatch as u,parse as a}from"date-fns";import{zonedTimeToUtc as f,formatInTimeZone as c}from"date-fns-tz/esm";function l(n,t){(null==t||t>n.length)&&(t=n.length);for(var e=0,r=new Array(t);e<t;e++)r[e]=n[e];return r}var h=["yyyy-MM-dd","dd/MM/yyyy","dd/MM/yy","dd-MM-yyyy","dd-MM-yy","dd.MM.yyyy","dd.MM.yy"],s=["HH:mm","HH.mm","hh:mm a","hh:mm A"],d=function n(t){return t.children.map(function(e){var r={};return"list"===e.type?n(t):"listItem"===e.type?(r.checked=e.checked,e.children.map(function(n){if("paragraph"===n.type)return r.text=n.children.map(function(n){return"link"===n.type?n.children[0].value:n.value}).filter(function(n){return!!n}).join(""),r}).filter(function(n){return!!n})):void 0}).filter(function(n){return!!n})};function m(n,t,e){if(!n.s){if(e instanceof y){if(!e.s)return void(e.o=m.bind(null,n,t));1&t&&(t=e.s),e=e.v}if(e&&e.then)return void e.then(m.bind(null,n,t),m.bind(null,n,2));n.s=t,n.v=e;var r=n.o;r&&r(n)}}var p=function(p){try{var g,b,M,x,w,k,O,A,I,j,H,S,T;return Promise.resolve(n().use(t).use(e).parse(p)).then(function(t){function p(){for(H in U)(T=(S=U[H]).content.filter(Boolean))&&T.length>0&&(1===T.length&&(S.text=T[0]),S.text=T.join("\n\n")),S.content=T;return U}if(!t)return[];var U={},C=null;g=function(n,t){var e="undefined"!=typeof Symbol&&n[Symbol.iterator]||n["@@iterator"];if(e)return(e=e.call(n)).next.bind(e);if(Array.isArray(n)||(e=function(n,t){if(n){if("string"==typeof n)return l(n,t);var e=Object.prototype.toString.call(n).slice(8,-1);return"Object"===e&&n.constructor&&(e=n.constructor.name),"Map"===e||"Set"===e?Array.from(n):"Arguments"===e||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(e)?l(n,t):void 0}}(n))){e&&(n=e);var r=0;return function(){return r>=n.length?{done:!0}:{done:!1,value:n[r++]}}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}(t.children);var E=function(n,t,e){for(var r;;){var i=n();if(v(i)&&(i=i.v),!i)return o;if(i.then){r=0;break}var o=e();if(o&&o.then){if(!v(o)){r=1;break}o=o.s}}var u=new y,a=m.bind(null,u,2);return(0===r?i.then(c):1===r?o.then(f):(void 0).then(function(){(i=n())?i.then?i.then(c).then(void 0,a):c(i):m(u,1,o)})).then(void 0,a),u;function f(t){o=t;do{if(!(i=n())||v(i)&&!i.v)return void m(u,1,o);if(i.then)return void i.then(c).then(void 0,a);v(o=e())&&(o=o.v)}while(!o||!o.then);o.then(f).then(void 0,a)}function c(n){n?(o=e())&&o.then?o.then(f).then(void 0,a):f(o):m(u,1,o)}}(function(){return!(b=g()).done},0,function(){return M=b.value,Promise.resolve(n().use(e).use(i).stringify(M)).then(function(n){var t,e;(x=o(n)).indexOf("\\_")>-1&&(x=x.replace(/\\_/g,"_")),"heading"===M.type&&3===M.depth?(C=r(M.children[0].value),U[C]={title:M.children[0].value,content:[]}):"paragraph"===M.type&&C?(w=U[C],t=x,e=h.map(function(n){return u(t,n)}),k=e.indexOf(!0)>-1?f(a(t,h[e.indexOf(!0)],new Date),"UTC").toJSON().split("T")[0]:null,O=function(n){var t=s.map(function(t){return u(n,t)});if(t.indexOf(!0)>-1){var e=f(a(n,s[t.indexOf(!0)],new Date),"UTC");return c(e,"UTC","HH:mm")}return null}(x),A=function(n){var t=!1,e={hours:0,minutes:0},r=new RegExp(/([0-9]+)h([0-9]+)m/),i=new RegExp(/([0-9]+)h/);if(n.match(r)){t=!0;var o=n.match(r),u=o[2];e.hours=parseInt(o[1]),e.minutes=parseInt(u)}else if(n.match(i)){t=!0;var a=n.match(i);e.hours=parseInt(a[1]),e.minutes=0}return t?e:null}(x),k&&(w.date=k),O&&(w.time=O),A&&(w.duration=A),w.content.push(x)):"list"===M.type?((I=U[C]).text=x,I.list=d(M).flat()):"html"===M.type?U[C].content.push(M.html):"code"===M.type?((j=U[C]).lang=M.lang,j.text=x):"heading"===M.type&&M.depth>3?U[C].content.push(M.children[0].value):process.env.DEBUG&&(console.log("unhandled token type"),console.log(M))})});return E&&E.then?E.then(p):p()})}catch(n){return Promise.reject(n)}};const y=/*#__PURE__*/function(){function n(){}return n.prototype.then=function(t,e){const r=new n,i=this.s;if(i){const n=1&i?t:e;if(n){try{m(r,1,n(this.v))}catch(n){m(r,2,n)}return r}return this}return this.o=function(n){try{const i=n.v;1&n.s?m(r,1,t?t(i):i):e?m(r,1,e(i)):m(r,2,i)}catch(n){m(r,2,n)}},r},n}();function v(n){return n instanceof y&&1&n.s}export{p as default};
1
+ import{unified as n}from"unified";import t from"remark-parse";import e from"remark-gfm";import r from"@sindresorhus/slugify";import i from"remark-stringify";import o from"strip-final-newline";import{isMatch as u,parse as a}from"date-fns";import{zonedTimeToUtc as f,formatInTimeZone as l}from"date-fns-tz/esm";function c(n,t){(null==t||t>n.length)&&(t=n.length);for(var e=0,r=new Array(t);e<t;e++)r[e]=n[e];return r}var h=["yyyy-MM-dd","dd/MM/yyyy","dd/MM/yy","dd-MM-yyyy","dd-MM-yy","dd.MM.yyyy","dd.MM.yy"],s=["HH:mm","HH.mm","hh:mm a","hh:mm A"],d=function n(t){return t.children.map(function(e){var r={};return"list"===e.type?n(t):"listItem"===e.type?(r.checked=e.checked,e.children.map(function(n){if("paragraph"===n.type)return r.text=n.children.map(function(n){return"link"===n.type?(r.link=n.url,"["+n.children[0].value+"]("+n.url+")"):n.value}).filter(function(n){return!!n}).join(""),r}).filter(function(n){return!!n})):void 0}).filter(function(n){return!!n})};function m(n,t,e){if(!n.s){if(e instanceof y){if(!e.s)return void(e.o=m.bind(null,n,t));1&t&&(t=e.s),e=e.v}if(e&&e.then)return void e.then(m.bind(null,n,t),m.bind(null,n,2));n.s=t,n.v=e;var r=n.o;r&&r(n)}}var p=function(p){try{var g,b,M,x,w,k,O,A,I,j,H,S,T;return Promise.resolve(n().use(t).use(e).parse(p)).then(function(t){function p(){for(H in U)(T=(S=U[H]).content.filter(Boolean))&&T.length>0&&(1===T.length&&(S.text=T[0]),S.text=T.join("\n\n")),S.content=T;return U}if(!t)return[];var U={},C=null;g=function(n,t){var e="undefined"!=typeof Symbol&&n[Symbol.iterator]||n["@@iterator"];if(e)return(e=e.call(n)).next.bind(e);if(Array.isArray(n)||(e=function(n,t){if(n){if("string"==typeof n)return c(n,t);var e=Object.prototype.toString.call(n).slice(8,-1);return"Object"===e&&n.constructor&&(e=n.constructor.name),"Map"===e||"Set"===e?Array.from(n):"Arguments"===e||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(e)?c(n,t):void 0}}(n))){e&&(n=e);var r=0;return function(){return r>=n.length?{done:!0}:{done:!1,value:n[r++]}}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}(t.children);var E=function(n,t,e){for(var r;;){var i=n();if(v(i)&&(i=i.v),!i)return o;if(i.then){r=0;break}var o=e();if(o&&o.then){if(!v(o)){r=1;break}o=o.s}}var u=new y,a=m.bind(null,u,2);return(0===r?i.then(l):1===r?o.then(f):(void 0).then(function(){(i=n())?i.then?i.then(l).then(void 0,a):l(i):m(u,1,o)})).then(void 0,a),u;function f(t){o=t;do{if(!(i=n())||v(i)&&!i.v)return void m(u,1,o);if(i.then)return void i.then(l).then(void 0,a);v(o=e())&&(o=o.v)}while(!o||!o.then);o.then(f).then(void 0,a)}function l(n){n?(o=e())&&o.then?o.then(f).then(void 0,a):f(o):m(u,1,o)}}(function(){return!(b=g()).done},0,function(){return M=b.value,Promise.resolve(n().use(e).use(i).stringify(M)).then(function(n){var t,e;(x=o(n)).indexOf("\\_")>-1&&(x=x.replace(/\\_/g,"_")),"heading"===M.type?(C=r(M.children[0].value),U[C]={title:M.children[0].value,heading:M.depth,content:[]}):"paragraph"===M.type&&C?(w=U[C],t=x,e=h.map(function(n){return u(t,n)}),k=e.indexOf(!0)>-1?f(a(t,h[e.indexOf(!0)],new Date),"UTC").toJSON().split("T")[0]:null,O=function(n){var t=s.map(function(t){return u(n,t)});if(t.indexOf(!0)>-1){var e=f(a(n,s[t.indexOf(!0)],new Date),"UTC");return l(e,"UTC","HH:mm")}return null}(x),A=function(n){var t=!1,e={hours:0,minutes:0},r=new RegExp(/([0-9]+)h([0-9]+)m/),i=new RegExp(/([0-9]+)h/);if(n.match(r)){t=!0;var o=n.match(r),u=o[2];e.hours=parseInt(o[1]),e.minutes=parseInt(u)}else if(n.match(i)){t=!0;var a=n.match(i);e.hours=parseInt(a[1]),e.minutes=0}return t?e:null}(x),k&&(w.date=k),O&&(w.time=O),A&&(w.duration=A),w.content.push(x)):"list"===M.type?((I=U[C]).text=x,I.list=d(M).flat()):"html"===M.type?U[C].content.push(M.html):"code"===M.type?((j=U[C]).lang=M.lang,j.text=x):process.env.DEBUG&&(console.log("unhandled token type"),console.log(M))})});return E&&E.then?E.then(p):p()})}catch(n){return Promise.reject(n)}};const y=/*#__PURE__*/function(){function n(){}return n.prototype.then=function(t,e){const r=new n,i=this.s;if(i){const n=1&i?t:e;if(n){try{m(r,1,n(this.v))}catch(n){m(r,2,n)}return r}return this}return this.o=function(n){try{const i=n.v;1&n.s?m(r,1,t?t(i):i):e?m(r,1,e(i)):m(r,2,i)}catch(n){m(r,2,n)}},r},n}();function v(n){return n instanceof y&&1&n.s}export{p as default};
2
2
  //# sourceMappingURL=parse.js.map
package/pkg/parse.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"parse.js","sources":["../src/parsers/date.js","../src/parsers/time.js","../src/parsers/index.js","../src/parsers/list.js","../src/parse.js","../src/parsers/duration.js"],"sourcesContent":["'use strict'\n\nimport { parse, isMatch } from 'date-fns'\nimport { zonedTimeToUtc } from 'date-fns-tz/esm'\n\nconst loc = 'UTC'\nconst commonDateFormats = [\n 'yyyy-MM-dd',\n 'dd/MM/yyyy',\n 'dd/MM/yy',\n 'dd-MM-yyyy',\n 'dd-MM-yy',\n 'dd.MM.yyyy',\n 'dd.MM.yy'\n]\n\nexport default function parseDate(text) {\n const match = commonDateFormats.map((format) => {\n return isMatch(text, format)\n })\n if (match.indexOf(true) > -1) {\n const date = zonedTimeToUtc(\n parse(text, commonDateFormats[match.indexOf(true)], new Date()),\n loc\n ).toJSON()\n return date.split('T')[0]\n } else {\n return null\n }\n}\n","'use strict'\n\nimport { parse, isMatch } from 'date-fns'\nimport { zonedTimeToUtc, formatInTimeZone } from 'date-fns-tz/esm'\n\nconst loc = 'UTC'\nconst commonTimeFormats = ['HH:mm', 'HH.mm', 'hh:mm a', 'hh:mm A']\n\nexport default function parseTime(text) {\n const match = commonTimeFormats.map((format) => {\n return isMatch(text, format)\n })\n if (match.indexOf(true) > -1) {\n const time = zonedTimeToUtc(\n parse(text, commonTimeFormats[match.indexOf(true)], new Date()),\n loc\n )\n return formatInTimeZone(time, loc, 'HH:mm')\n } else {\n return null\n }\n}\n","'use strict'\n\nimport date from './date.js'\nimport time from './time.js'\nimport duration from './duration.js'\nimport list from './list.js'\n\nexport const parseDate = date\nexport const parseTime = time\nexport const parseDuration = duration\nexport const parseList = list\n","'use strict'\n\nexport default function parseList(list) {\n return list.children\n .map((item) => {\n const listItem = {}\n if (item.type === 'list') {\n return parseList(list)\n } else if (item.type === 'listItem') {\n listItem.checked = item.checked\n return item.children\n .map((child) => {\n if (child.type === 'paragraph') {\n listItem.text = child.children\n .map((c) => {\n if (c.type === 'link') {\n return c.children[0].value\n } else {\n return c.value\n }\n })\n .filter((x) => !!x)\n .join('')\n return listItem\n }\n })\n .filter((x) => !!x)\n }\n })\n .filter((x) => !!x)\n}\n","'use strict'\n\nimport { unified } from 'unified'\nimport remarkParse from 'remark-parse'\nimport remarkGfm from 'remark-gfm'\nimport slugify from '@sindresorhus/slugify'\nimport remarkStringify from 'remark-stringify'\nimport stripFinalNewline from 'strip-final-newline'\n\nimport {\n parseDate,\n parseTime,\n parseDuration,\n parseList\n} from './parsers/index.js'\n\nexport default async function parseMD(body) {\n const tokens = await unified().use(remarkParse).use(remarkGfm).parse(body)\n if (!tokens) {\n return []\n }\n\n const structuredResponse = {}\n let currentHeading = null\n for (const token of tokens.children) {\n const text = await unified()\n .use(remarkGfm)\n .use(remarkStringify)\n .stringify(token)\n let cleanText = stripFinalNewline(text)\n\n // remove `\\\\_`\n if (cleanText.indexOf('\\\\_') > -1) {\n cleanText = cleanText.replace(/\\\\_/g, '_')\n }\n\n // issue forms uses h3 as a heading\n if (token.type === 'heading' && token.depth === 3) {\n currentHeading = slugify(token.children[0].value)\n structuredResponse[currentHeading] = {\n title: token.children[0].value,\n content: []\n }\n } else if (token.type === 'paragraph' && currentHeading) {\n const obj = structuredResponse[currentHeading]\n\n const date = parseDate(cleanText)\n const time = parseTime(cleanText)\n const duration = parseDuration(cleanText)\n\n if (date) {\n obj.date = date\n }\n\n if (time) {\n obj.time = time\n }\n\n if (duration) {\n obj.duration = duration\n }\n\n obj.content.push(cleanText)\n } else if (token.type === 'list') {\n const obj = structuredResponse[currentHeading]\n obj.text = cleanText\n obj.list = parseList(token).flat()\n } else if (token.type === 'html') {\n const obj = structuredResponse[currentHeading]\n obj.content.push(token.html)\n } else if (token.type === 'code') {\n const obj = structuredResponse[currentHeading]\n obj.lang = token.lang\n obj.text = cleanText\n } else if (token.type === 'heading' && token.depth > 3) {\n const obj = structuredResponse[currentHeading]\n obj.content.push(token.children[0].value)\n } else {\n if(process.env.DEBUG){\n console.log('unhandled token type')\n console.log(token) \n }\n }\n }\n\n for (const key in structuredResponse) {\n const token = structuredResponse[key]\n const content = token.content.filter(Boolean)\n if (content && content.length > 0) {\n if (content.length === 1) {\n token.text = content[0]\n }\n token.text = content.join('\\n\\n')\n }\n token.content = content\n }\n\n return structuredResponse\n}\n","'use strict'\n\nexport default function parseDuration(text) {\n let matched = false\n const duration = {\n hours: 0,\n minutes: 0\n }\n\n const hoursAndMinutes = new RegExp(/([0-9]+)h([0-9]+)m/)\n const hours = new RegExp(/([0-9]+)h/)\n\n if (text.match(hoursAndMinutes)) {\n matched = true\n const [, h, m] = text.match(hoursAndMinutes)\n duration.hours = parseInt(h)\n duration.minutes = parseInt(m)\n } else if (text.match(hours)) {\n matched = true\n const [, h] = text.match(hours)\n duration.hours = parseInt(h)\n duration.minutes = 0\n }\n\n if (matched) {\n return duration\n } else {\n return null\n }\n}\n"],"names":["commonDateFormats","commonTimeFormats","parseList","list","children","map","item","listItem","type","checked","child","text","c","value","filter","x","join","_settle","pact","state","s","_Pact","o","bind","v","then","observer","parseMD","body","token","cleanText","obj","date","time","duration","key","content","unified","use","remarkParse","remarkGfm","parse","tokens","_temp2","structuredResponse","Boolean","length","currentHeading","_iterator","_createForOfIteratorHelperLoose","_temp","test","update","stage","shouldContinue","_isSettledPact","result","reject","_resumeAfterTest","_resumeAfterBody","updateValue","_for","_step","done","Promise","resolve","remarkStringify","stringify","_unified$use$use$stri","match","stripFinalNewline","indexOf","replace","depth","slugify","title","format","isMatch","zonedTimeToUtc","Date","toJSON","split","parseTime","formatInTimeZone","matched","hours","minutes","hoursAndMinutes","RegExp","_text$match","m","parseInt","parseDuration","push","flat","html","lang","process","env","DEBUG","console","log","prototype","onFulfilled","onRejected","this","callback","e","_this","thenable"],"mappings":"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"}
1
+ {"version":3,"file":"parse.js","sources":["../src/parsers/date.js","../src/parsers/time.js","../src/parsers/index.js","../src/parsers/list.js","../src/parse.js","../src/parsers/duration.js"],"sourcesContent":["'use strict'\n\nimport { parse, isMatch } from 'date-fns'\nimport { zonedTimeToUtc } from 'date-fns-tz/esm'\n\nconst loc = 'UTC'\nconst commonDateFormats = [\n 'yyyy-MM-dd',\n 'dd/MM/yyyy',\n 'dd/MM/yy',\n 'dd-MM-yyyy',\n 'dd-MM-yy',\n 'dd.MM.yyyy',\n 'dd.MM.yy'\n]\n\nexport default function parseDate(text) {\n const match = commonDateFormats.map((format) => {\n return isMatch(text, format)\n })\n if (match.indexOf(true) > -1) {\n const date = zonedTimeToUtc(\n parse(text, commonDateFormats[match.indexOf(true)], new Date()),\n loc\n ).toJSON()\n return date.split('T')[0]\n } else {\n return null\n }\n}\n","'use strict'\n\nimport { parse, isMatch } from 'date-fns'\nimport { zonedTimeToUtc, formatInTimeZone } from 'date-fns-tz/esm'\n\nconst loc = 'UTC'\nconst commonTimeFormats = ['HH:mm', 'HH.mm', 'hh:mm a', 'hh:mm A']\n\nexport default function parseTime(text) {\n const match = commonTimeFormats.map((format) => {\n return isMatch(text, format)\n })\n if (match.indexOf(true) > -1) {\n const time = zonedTimeToUtc(\n parse(text, commonTimeFormats[match.indexOf(true)], new Date()),\n loc\n )\n return formatInTimeZone(time, loc, 'HH:mm')\n } else {\n return null\n }\n}\n","'use strict'\n\nimport date from './date.js'\nimport time from './time.js'\nimport duration from './duration.js'\nimport list from './list.js'\n\nexport const parseDate = date\nexport const parseTime = time\nexport const parseDuration = duration\nexport const parseList = list\n","'use strict'\n\nexport default function parseList(list) {\n return list.children\n .map((item) => {\n const listItem = {}\n if (item.type === 'list') {\n return parseList(list)\n } else if (item.type === 'listItem') {\n listItem.checked = item.checked\n return item.children\n .map((child) => {\n if (child.type === 'paragraph') {\n listItem.text = child.children\n .map((c) => {\n if (c.type === 'link') {\n listItem.link = c.url\n return `[${c.children[0].value}](${c.url})`\n } else {\n return c.value\n }\n })\n .filter((x) => !!x)\n .join('')\n return listItem\n }\n })\n .filter((x) => !!x)\n }\n })\n .filter((x) => !!x)\n}\n","'use strict'\n\nimport { unified } from 'unified'\nimport remarkParse from 'remark-parse'\nimport remarkGfm from 'remark-gfm'\nimport slugify from '@sindresorhus/slugify'\nimport remarkStringify from 'remark-stringify'\nimport stripFinalNewline from 'strip-final-newline'\n\nimport {\n parseDate,\n parseTime,\n parseDuration,\n parseList\n} from './parsers/index.js'\n\nexport default async function parseMD(body) {\n const tokens = await unified().use(remarkParse).use(remarkGfm).parse(body)\n if (!tokens) {\n return []\n }\n\n const structuredResponse = {}\n let currentHeading = null\n for (const token of tokens.children) {\n const text = await unified()\n .use(remarkGfm)\n .use(remarkStringify)\n .stringify(token)\n let cleanText = stripFinalNewline(text)\n\n // remove `\\\\_`\n if (cleanText.indexOf('\\\\_') > -1) {\n cleanText = cleanText.replace(/\\\\_/g, '_')\n }\n\n // issue forms uses h3 as a heading\n if (token.type === 'heading') {\n currentHeading = slugify(token.children[0].value)\n structuredResponse[currentHeading] = {\n title: token.children[0].value,\n heading: token.depth,\n content: []\n }\n } else if (token.type === 'paragraph' && currentHeading) {\n const obj = structuredResponse[currentHeading]\n\n const date = parseDate(cleanText)\n const time = parseTime(cleanText)\n const duration = parseDuration(cleanText)\n\n if (date) {\n obj.date = date\n }\n\n if (time) {\n obj.time = time\n }\n\n if (duration) {\n obj.duration = duration\n }\n\n obj.content.push(cleanText)\n } else if (token.type === 'list') {\n const obj = structuredResponse[currentHeading]\n obj.text = cleanText\n obj.list = parseList(token).flat()\n } else if (token.type === 'html') {\n const obj = structuredResponse[currentHeading]\n obj.content.push(token.html)\n } else if (token.type === 'code') {\n const obj = structuredResponse[currentHeading]\n obj.lang = token.lang\n obj.text = cleanText\n } else {\n if (process.env.DEBUG) {\n console.log('unhandled token type')\n console.log(token)\n }\n }\n }\n\n for (const key in structuredResponse) {\n const token = structuredResponse[key]\n const content = token.content.filter(Boolean)\n if (content && content.length > 0) {\n if (content.length === 1) {\n token.text = content[0]\n }\n token.text = content.join('\\n\\n')\n }\n token.content = content\n }\n\n return structuredResponse\n}\n","'use strict'\n\nexport default function parseDuration(text) {\n let matched = false\n const duration = {\n hours: 0,\n minutes: 0\n }\n\n const hoursAndMinutes = new RegExp(/([0-9]+)h([0-9]+)m/)\n const hours = new RegExp(/([0-9]+)h/)\n\n if (text.match(hoursAndMinutes)) {\n matched = true\n const [, h, m] = text.match(hoursAndMinutes)\n duration.hours = parseInt(h)\n duration.minutes = parseInt(m)\n } else if (text.match(hours)) {\n matched = true\n const [, h] = text.match(hours)\n duration.hours = parseInt(h)\n duration.minutes = 0\n }\n\n if (matched) {\n return duration\n } else {\n return null\n }\n}\n"],"names":["commonDateFormats","commonTimeFormats","parseList","list","children","map","item","listItem","type","checked","child","text","c","link","url","value","filter","x","join","_settle","pact","state","s","_Pact","o","bind","v","then","observer","parseMD","body","token","cleanText","obj","date","time","duration","key","content","unified","use","remarkParse","remarkGfm","parse","tokens","_temp2","structuredResponse","Boolean","length","currentHeading","_iterator","test","update","stage","shouldContinue","_isSettledPact","result","reject","_resumeAfterTest","_resumeAfterBody","updateValue","remarkStringify","stringify","match","stripFinalNewline","indexOf","replace","slugify","title","heading","depth","format","isMatch","zonedTimeToUtc","Date","toJSON","split","parseTime","formatInTimeZone","matched","hours","minutes","hoursAndMinutes","RegExp","_text$match","m","parseInt","parseDuration","push","flat","html","lang","process","env","DEBUG","console","log","prototype","onFulfilled","onRejected","this","callback","e","_this","thenable"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- import{unified as e}from"unified";import t from"remark-parse";import n from"remark-gfm";import r from"@sindresorhus/slugify";import i from"remark-stringify";import o from"strip-final-newline";import{isMatch as s,parse as l}from"date-fns";import{zonedTimeToUtc as a,formatInTimeZone as c}from"date-fns-tz/esm";const m=["yyyy-MM-dd","dd/MM/yyyy","dd/MM/yy","dd-MM-yyyy","dd-MM-yy","dd.MM.yyyy","dd.MM.yy"],f=["HH:mm","HH.mm","hh:mm a","hh:mm A"],p=function(e){const t=m.map(t=>s(e,t));return t.indexOf(!0)>-1?a(l(e,m[t.indexOf(!0)],new Date),"UTC").toJSON().split("T")[0]:null},d=function(e){const t=f.map(t=>s(e,t));if(t.indexOf(!0)>-1){const n=a(l(e,f[t.indexOf(!0)],new Date),"UTC");return c(n,"UTC","HH:mm")}return null},u=function(e){let t=!1;const n={hours:0,minutes:0},r=new RegExp(/([0-9]+)h([0-9]+)m/),i=new RegExp(/([0-9]+)h/);if(e.match(r)){t=!0;const[,i,o]=e.match(r);n.hours=parseInt(i),n.minutes=parseInt(o)}else if(e.match(i)){t=!0;const[,r]=e.match(i);n.hours=parseInt(r),n.minutes=0}return t?n:null},h=function e(t){return t.children.map(n=>{const r={};return"list"===n.type?e(t):"listItem"===n.type?(r.checked=n.checked,n.children.map(e=>{if("paragraph"===e.type)return r.text=e.children.map(e=>"link"===e.type?e.children[0].value:e.value).filter(e=>!!e).join(""),r}).filter(e=>!!e)):void 0}).filter(e=>!!e)};async function y(s){const l=await e().use(t).use(n).parse(s);if(!l)return[];const a={};let c=null;for(const t of l.children){const s=await e().use(n).use(i).stringify(t);let l=o(s);if(l.indexOf("\\_")>-1&&(l=l.replace(/\\_/g,"_")),"heading"===t.type&&3===t.depth)c=r(t.children[0].value),a[c]={title:t.children[0].value,content:[]};else if("paragraph"===t.type&&c){const e=a[c],t=p(l),n=d(l),r=u(l);t&&(e.date=t),n&&(e.time=n),r&&(e.duration=r),e.content.push(l)}else if("list"===t.type){const e=a[c];e.text=l,e.list=h(t).flat()}else if("html"===t.type)a[c].content.push(t.html);else if("code"===t.type){const e=a[c];e.lang=t.lang,e.text=l}else"heading"===t.type&&t.depth>3?a[c].content.push(t.children[0].value):process.env.DEBUG&&(console.log("unhandled token type"),console.log(t))}for(const e in a){const t=a[e],n=t.content.filter(Boolean);n&&n.length>0&&(1===n.length&&(t.text=n[0]),t.text=n.join("\n\n")),t.content=n}return a}export{y as default};
1
+ import{unified as e}from"unified";import t from"remark-parse";import n from"remark-gfm";import r from"@sindresorhus/slugify";import i from"remark-stringify";import o from"strip-final-newline";import{isMatch as s,parse as l}from"date-fns";import{zonedTimeToUtc as a,formatInTimeZone as c}from"date-fns-tz/esm";const m=["yyyy-MM-dd","dd/MM/yyyy","dd/MM/yy","dd-MM-yyyy","dd-MM-yy","dd.MM.yyyy","dd.MM.yy"],f=["HH:mm","HH.mm","hh:mm a","hh:mm A"],d=function(e){const t=m.map(t=>s(e,t));return t.indexOf(!0)>-1?a(l(e,m[t.indexOf(!0)],new Date),"UTC").toJSON().split("T")[0]:null},p=function(e){const t=f.map(t=>s(e,t));if(t.indexOf(!0)>-1){const n=a(l(e,f[t.indexOf(!0)],new Date),"UTC");return c(n,"UTC","HH:mm")}return null},u=function(e){let t=!1;const n={hours:0,minutes:0},r=new RegExp(/([0-9]+)h([0-9]+)m/),i=new RegExp(/([0-9]+)h/);if(e.match(r)){t=!0;const[,i,o]=e.match(r);n.hours=parseInt(i),n.minutes=parseInt(o)}else if(e.match(i)){t=!0;const[,r]=e.match(i);n.hours=parseInt(r),n.minutes=0}return t?n:null},y=function e(t){return t.children.map(n=>{const r={};return"list"===n.type?e(t):"listItem"===n.type?(r.checked=n.checked,n.children.map(e=>{if("paragraph"===e.type)return r.text=e.children.map(e=>"link"===e.type?(r.link=e.url,`[${e.children[0].value}](${e.url})`):e.value).filter(e=>!!e).join(""),r}).filter(e=>!!e)):void 0}).filter(e=>!!e)};async function h(s){const l=await e().use(t).use(n).parse(s);if(!l)return[];const a={};let c=null;for(const t of l.children){const s=await e().use(n).use(i).stringify(t);let l=o(s);if(l.indexOf("\\_")>-1&&(l=l.replace(/\\_/g,"_")),"heading"===t.type)c=r(t.children[0].value),a[c]={title:t.children[0].value,heading:t.depth,content:[]};else if("paragraph"===t.type&&c){const e=a[c],t=d(l),n=p(l),r=u(l);t&&(e.date=t),n&&(e.time=n),r&&(e.duration=r),e.content.push(l)}else if("list"===t.type){const e=a[c];e.text=l,e.list=y(t).flat()}else if("html"===t.type)a[c].content.push(t.html);else if("code"===t.type){const e=a[c];e.lang=t.lang,e.text=l}else process.env.DEBUG&&(console.log("unhandled token type"),console.log(t))}for(const e in a){const t=a[e],n=t.content.filter(Boolean);n&&n.length>0&&(1===n.length&&(t.text=n[0]),t.text=n.join("\n\n")),t.content=n}return a}export{h as default};
2
2
  //# sourceMappingURL=parse.modern.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"parse.modern.js","sources":["../src/parsers/date.js","../src/parsers/time.js","../src/parsers/index.js","../src/parsers/duration.js","../src/parsers/list.js","../src/parse.js"],"sourcesContent":["'use strict'\n\nimport { parse, isMatch } from 'date-fns'\nimport { zonedTimeToUtc } from 'date-fns-tz/esm'\n\nconst loc = 'UTC'\nconst commonDateFormats = [\n 'yyyy-MM-dd',\n 'dd/MM/yyyy',\n 'dd/MM/yy',\n 'dd-MM-yyyy',\n 'dd-MM-yy',\n 'dd.MM.yyyy',\n 'dd.MM.yy'\n]\n\nexport default function parseDate(text) {\n const match = commonDateFormats.map((format) => {\n return isMatch(text, format)\n })\n if (match.indexOf(true) > -1) {\n const date = zonedTimeToUtc(\n parse(text, commonDateFormats[match.indexOf(true)], new Date()),\n loc\n ).toJSON()\n return date.split('T')[0]\n } else {\n return null\n }\n}\n","'use strict'\n\nimport { parse, isMatch } from 'date-fns'\nimport { zonedTimeToUtc, formatInTimeZone } from 'date-fns-tz/esm'\n\nconst loc = 'UTC'\nconst commonTimeFormats = ['HH:mm', 'HH.mm', 'hh:mm a', 'hh:mm A']\n\nexport default function parseTime(text) {\n const match = commonTimeFormats.map((format) => {\n return isMatch(text, format)\n })\n if (match.indexOf(true) > -1) {\n const time = zonedTimeToUtc(\n parse(text, commonTimeFormats[match.indexOf(true)], new Date()),\n loc\n )\n return formatInTimeZone(time, loc, 'HH:mm')\n } else {\n return null\n }\n}\n","'use strict'\n\nimport date from './date.js'\nimport time from './time.js'\nimport duration from './duration.js'\nimport list from './list.js'\n\nexport const parseDate = date\nexport const parseTime = time\nexport const parseDuration = duration\nexport const parseList = list\n","'use strict'\n\nexport default function parseDuration(text) {\n let matched = false\n const duration = {\n hours: 0,\n minutes: 0\n }\n\n const hoursAndMinutes = new RegExp(/([0-9]+)h([0-9]+)m/)\n const hours = new RegExp(/([0-9]+)h/)\n\n if (text.match(hoursAndMinutes)) {\n matched = true\n const [, h, m] = text.match(hoursAndMinutes)\n duration.hours = parseInt(h)\n duration.minutes = parseInt(m)\n } else if (text.match(hours)) {\n matched = true\n const [, h] = text.match(hours)\n duration.hours = parseInt(h)\n duration.minutes = 0\n }\n\n if (matched) {\n return duration\n } else {\n return null\n }\n}\n","'use strict'\n\nexport default function parseList(list) {\n return list.children\n .map((item) => {\n const listItem = {}\n if (item.type === 'list') {\n return parseList(list)\n } else if (item.type === 'listItem') {\n listItem.checked = item.checked\n return item.children\n .map((child) => {\n if (child.type === 'paragraph') {\n listItem.text = child.children\n .map((c) => {\n if (c.type === 'link') {\n return c.children[0].value\n } else {\n return c.value\n }\n })\n .filter((x) => !!x)\n .join('')\n return listItem\n }\n })\n .filter((x) => !!x)\n }\n })\n .filter((x) => !!x)\n}\n","'use strict'\n\nimport { unified } from 'unified'\nimport remarkParse from 'remark-parse'\nimport remarkGfm from 'remark-gfm'\nimport slugify from '@sindresorhus/slugify'\nimport remarkStringify from 'remark-stringify'\nimport stripFinalNewline from 'strip-final-newline'\n\nimport {\n parseDate,\n parseTime,\n parseDuration,\n parseList\n} from './parsers/index.js'\n\nexport default async function parseMD(body) {\n const tokens = await unified().use(remarkParse).use(remarkGfm).parse(body)\n if (!tokens) {\n return []\n }\n\n const structuredResponse = {}\n let currentHeading = null\n for (const token of tokens.children) {\n const text = await unified()\n .use(remarkGfm)\n .use(remarkStringify)\n .stringify(token)\n let cleanText = stripFinalNewline(text)\n\n // remove `\\\\_`\n if (cleanText.indexOf('\\\\_') > -1) {\n cleanText = cleanText.replace(/\\\\_/g, '_')\n }\n\n // issue forms uses h3 as a heading\n if (token.type === 'heading' && token.depth === 3) {\n currentHeading = slugify(token.children[0].value)\n structuredResponse[currentHeading] = {\n title: token.children[0].value,\n content: []\n }\n } else if (token.type === 'paragraph' && currentHeading) {\n const obj = structuredResponse[currentHeading]\n\n const date = parseDate(cleanText)\n const time = parseTime(cleanText)\n const duration = parseDuration(cleanText)\n\n if (date) {\n obj.date = date\n }\n\n if (time) {\n obj.time = time\n }\n\n if (duration) {\n obj.duration = duration\n }\n\n obj.content.push(cleanText)\n } else if (token.type === 'list') {\n const obj = structuredResponse[currentHeading]\n obj.text = cleanText\n obj.list = parseList(token).flat()\n } else if (token.type === 'html') {\n const obj = structuredResponse[currentHeading]\n obj.content.push(token.html)\n } else if (token.type === 'code') {\n const obj = structuredResponse[currentHeading]\n obj.lang = token.lang\n obj.text = cleanText\n } else if (token.type === 'heading' && token.depth > 3) {\n const obj = structuredResponse[currentHeading]\n obj.content.push(token.children[0].value)\n } else {\n if(process.env.DEBUG){\n console.log('unhandled token type')\n console.log(token) \n }\n }\n }\n\n for (const key in structuredResponse) {\n const token = structuredResponse[key]\n const content = token.content.filter(Boolean)\n if (content && content.length > 0) {\n if (content.length === 1) {\n token.text = content[0]\n }\n token.text = content.join('\\n\\n')\n }\n token.content = content\n }\n\n return structuredResponse\n}\n"],"names":["commonDateFormats","commonTimeFormats","parseDate","text","match","map","format","isMatch","indexOf","zonedTimeToUtc","parse","Date","toJSON","split","parseTime","time","formatInTimeZone","parseDuration","matched","duration","hours","minutes","hoursAndMinutes","RegExp","h","m","parseInt","parseList","list","children","item","listItem","type","checked","child","c","value","filter","x","join","parseMD","body","tokens","unified","use","remarkParse","remarkGfm","structuredResponse","currentHeading","token","remarkStringify","stringify","cleanText","stripFinalNewline","replace","depth","slugify","title","content","obj","date","push","flat","html","lang","process","env","DEBUG","console","log","key","Boolean","length"],"mappings":"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"}
1
+ {"version":3,"file":"parse.modern.js","sources":["../src/parsers/date.js","../src/parsers/time.js","../src/parsers/index.js","../src/parsers/duration.js","../src/parsers/list.js","../src/parse.js"],"sourcesContent":["'use strict'\n\nimport { parse, isMatch } from 'date-fns'\nimport { zonedTimeToUtc } from 'date-fns-tz/esm'\n\nconst loc = 'UTC'\nconst commonDateFormats = [\n 'yyyy-MM-dd',\n 'dd/MM/yyyy',\n 'dd/MM/yy',\n 'dd-MM-yyyy',\n 'dd-MM-yy',\n 'dd.MM.yyyy',\n 'dd.MM.yy'\n]\n\nexport default function parseDate(text) {\n const match = commonDateFormats.map((format) => {\n return isMatch(text, format)\n })\n if (match.indexOf(true) > -1) {\n const date = zonedTimeToUtc(\n parse(text, commonDateFormats[match.indexOf(true)], new Date()),\n loc\n ).toJSON()\n return date.split('T')[0]\n } else {\n return null\n }\n}\n","'use strict'\n\nimport { parse, isMatch } from 'date-fns'\nimport { zonedTimeToUtc, formatInTimeZone } from 'date-fns-tz/esm'\n\nconst loc = 'UTC'\nconst commonTimeFormats = ['HH:mm', 'HH.mm', 'hh:mm a', 'hh:mm A']\n\nexport default function parseTime(text) {\n const match = commonTimeFormats.map((format) => {\n return isMatch(text, format)\n })\n if (match.indexOf(true) > -1) {\n const time = zonedTimeToUtc(\n parse(text, commonTimeFormats[match.indexOf(true)], new Date()),\n loc\n )\n return formatInTimeZone(time, loc, 'HH:mm')\n } else {\n return null\n }\n}\n","'use strict'\n\nimport date from './date.js'\nimport time from './time.js'\nimport duration from './duration.js'\nimport list from './list.js'\n\nexport const parseDate = date\nexport const parseTime = time\nexport const parseDuration = duration\nexport const parseList = list\n","'use strict'\n\nexport default function parseDuration(text) {\n let matched = false\n const duration = {\n hours: 0,\n minutes: 0\n }\n\n const hoursAndMinutes = new RegExp(/([0-9]+)h([0-9]+)m/)\n const hours = new RegExp(/([0-9]+)h/)\n\n if (text.match(hoursAndMinutes)) {\n matched = true\n const [, h, m] = text.match(hoursAndMinutes)\n duration.hours = parseInt(h)\n duration.minutes = parseInt(m)\n } else if (text.match(hours)) {\n matched = true\n const [, h] = text.match(hours)\n duration.hours = parseInt(h)\n duration.minutes = 0\n }\n\n if (matched) {\n return duration\n } else {\n return null\n }\n}\n","'use strict'\n\nexport default function parseList(list) {\n return list.children\n .map((item) => {\n const listItem = {}\n if (item.type === 'list') {\n return parseList(list)\n } else if (item.type === 'listItem') {\n listItem.checked = item.checked\n return item.children\n .map((child) => {\n if (child.type === 'paragraph') {\n listItem.text = child.children\n .map((c) => {\n if (c.type === 'link') {\n listItem.link = c.url\n return `[${c.children[0].value}](${c.url})`\n } else {\n return c.value\n }\n })\n .filter((x) => !!x)\n .join('')\n return listItem\n }\n })\n .filter((x) => !!x)\n }\n })\n .filter((x) => !!x)\n}\n","'use strict'\n\nimport { unified } from 'unified'\nimport remarkParse from 'remark-parse'\nimport remarkGfm from 'remark-gfm'\nimport slugify from '@sindresorhus/slugify'\nimport remarkStringify from 'remark-stringify'\nimport stripFinalNewline from 'strip-final-newline'\n\nimport {\n parseDate,\n parseTime,\n parseDuration,\n parseList\n} from './parsers/index.js'\n\nexport default async function parseMD(body) {\n const tokens = await unified().use(remarkParse).use(remarkGfm).parse(body)\n if (!tokens) {\n return []\n }\n\n const structuredResponse = {}\n let currentHeading = null\n for (const token of tokens.children) {\n const text = await unified()\n .use(remarkGfm)\n .use(remarkStringify)\n .stringify(token)\n let cleanText = stripFinalNewline(text)\n\n // remove `\\\\_`\n if (cleanText.indexOf('\\\\_') > -1) {\n cleanText = cleanText.replace(/\\\\_/g, '_')\n }\n\n // issue forms uses h3 as a heading\n if (token.type === 'heading') {\n currentHeading = slugify(token.children[0].value)\n structuredResponse[currentHeading] = {\n title: token.children[0].value,\n heading: token.depth,\n content: []\n }\n } else if (token.type === 'paragraph' && currentHeading) {\n const obj = structuredResponse[currentHeading]\n\n const date = parseDate(cleanText)\n const time = parseTime(cleanText)\n const duration = parseDuration(cleanText)\n\n if (date) {\n obj.date = date\n }\n\n if (time) {\n obj.time = time\n }\n\n if (duration) {\n obj.duration = duration\n }\n\n obj.content.push(cleanText)\n } else if (token.type === 'list') {\n const obj = structuredResponse[currentHeading]\n obj.text = cleanText\n obj.list = parseList(token).flat()\n } else if (token.type === 'html') {\n const obj = structuredResponse[currentHeading]\n obj.content.push(token.html)\n } else if (token.type === 'code') {\n const obj = structuredResponse[currentHeading]\n obj.lang = token.lang\n obj.text = cleanText\n } else {\n if (process.env.DEBUG) {\n console.log('unhandled token type')\n console.log(token)\n }\n }\n }\n\n for (const key in structuredResponse) {\n const token = structuredResponse[key]\n const content = token.content.filter(Boolean)\n if (content && content.length > 0) {\n if (content.length === 1) {\n token.text = content[0]\n }\n token.text = content.join('\\n\\n')\n }\n token.content = content\n }\n\n return structuredResponse\n}\n"],"names":["commonDateFormats","commonTimeFormats","parseDate","text","match","map","format","isMatch","indexOf","zonedTimeToUtc","parse","Date","toJSON","split","parseTime","time","formatInTimeZone","parseDuration","matched","duration","hours","minutes","hoursAndMinutes","RegExp","h","m","parseInt","parseList","list","children","item","listItem","type","checked","child","c","link","url","value","filter","x","join","parseMD","body","tokens","unified","use","remarkParse","remarkGfm","structuredResponse","currentHeading","token","remarkStringify","stringify","cleanText","stripFinalNewline","replace","slugify","title","heading","depth","content","obj","date","push","flat","html","lang","process","env","DEBUG","console","log","key","Boolean","length"],"mappings":"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"}
package/pkg/parse.umd.js CHANGED
@@ -1,2 +1,2 @@
1
- !function(e,n){"object"==typeof exports&&"undefined"!=typeof module?module.exports=n(require("unified"),require("remark-parse"),require("remark-gfm"),require("@sindresorhus/slugify"),require("remark-stringify"),require("strip-final-newline"),require("date-fns"),require("date-fns-tz/esm")):"function"==typeof define&&define.amd?define(["unified","remark-parse","remark-gfm","@sindresorhus/slugify","remark-stringify","strip-final-newline","date-fns","date-fns-tz/esm"],n):(e||self).issueFormsBodyParser=n(e.unified,e.remarkParse,e.remarkGfm,e.slugify,e.remarkStringify,e.stripFinalNewline,e.dateFns,e.esm)}(this,function(e,n,t,r,i,o,u,a){function f(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var l=/*#__PURE__*/f(n),s=/*#__PURE__*/f(t),d=/*#__PURE__*/f(r),c=/*#__PURE__*/f(i),h=/*#__PURE__*/f(o);function m(e,n){(null==n||n>e.length)&&(n=e.length);for(var t=0,r=new Array(n);t<n;t++)r[t]=e[t];return r}var y=["yyyy-MM-dd","dd/MM/yyyy","dd/MM/yy","dd-MM-yyyy","dd-MM-yy","dd.MM.yyyy","dd.MM.yy"],p=["HH:mm","HH.mm","hh:mm a","hh:mm A"],v=function e(n){return n.children.map(function(t){var r={};return"list"===t.type?e(n):"listItem"===t.type?(r.checked=t.checked,t.children.map(function(e){if("paragraph"===e.type)return r.text=e.children.map(function(e){return"link"===e.type?e.children[0].value:e.value}).filter(function(e){return!!e}).join(""),r}).filter(function(e){return!!e})):void 0}).filter(function(e){return!!e})};function g(e,n,t){if(!e.s){if(t instanceof b){if(!t.s)return void(t.o=g.bind(null,e,n));1&n&&(n=t.s),t=t.v}if(t&&t.then)return void t.then(g.bind(null,e,n),g.bind(null,e,2));e.s=n,e.v=t;var r=e.o;r&&r(e)}}const b=/*#__PURE__*/function(){function e(){}return e.prototype.then=function(n,t){const r=new e,i=this.s;if(i){const e=1&i?n:t;if(e){try{g(r,1,e(this.v))}catch(e){g(r,2,e)}return r}return this}return this.o=function(e){try{const i=e.v;1&e.s?g(r,1,n?n(i):i):t?g(r,1,t(i)):g(r,2,i)}catch(e){g(r,2,e)}},r},e}();function M(e){return e instanceof b&&1&e.s}return function(n){try{var t,r,i,o,f,k,x,w,T,j,q,I,O;return Promise.resolve(e.unified().use(l.default).use(s.default).parse(n)).then(function(n){function l(){for(q in A)(O=(I=A[q]).content.filter(Boolean))&&O.length>0&&(1===O.length&&(I.text=O[0]),I.text=O.join("\n\n")),I.content=O;return A}if(!n)return[];var A={},S=null;t=function(e,n){var t="undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(t)return(t=t.call(e)).next.bind(t);if(Array.isArray(e)||(t=function(e,n){if(e){if("string"==typeof e)return m(e,n);var t=Object.prototype.toString.call(e).slice(8,-1);return"Object"===t&&e.constructor&&(t=e.constructor.name),"Map"===t||"Set"===t?Array.from(e):"Arguments"===t||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t)?m(e,n):void 0}}(e))){t&&(e=t);var r=0;return function(){return r>=e.length?{done:!0}:{done:!1,value:e[r++]}}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}(n.children);var U=function(e,n,t){for(var r;;){var i=e();if(M(i)&&(i=i.v),!i)return o;if(i.then){r=0;break}var o=t();if(o&&o.then){if(!M(o)){r=1;break}o=o.s}}var u=new b,a=g.bind(null,u,2);return(0===r?i.then(l):1===r?o.then(f):(void 0).then(function(){(i=e())?i.then?i.then(l).then(void 0,a):l(i):g(u,1,o)})).then(void 0,a),u;function f(n){o=n;do{if(!(i=e())||M(i)&&!i.v)return void g(u,1,o);if(i.then)return void i.then(l).then(void 0,a);M(o=t())&&(o=o.v)}while(!o||!o.then);o.then(f).then(void 0,a)}function l(e){e?(o=t())&&o.then?o.then(f).then(void 0,a):f(o):g(u,1,o)}}(function(){return!(r=t()).done},0,function(){return i=r.value,Promise.resolve(e.unified().use(s.default).use(c.default).stringify(i)).then(function(e){var n,t;(o=h.default(e)).indexOf("\\_")>-1&&(o=o.replace(/\\_/g,"_")),"heading"===i.type&&3===i.depth?(S=d.default(i.children[0].value),A[S]={title:i.children[0].value,content:[]}):"paragraph"===i.type&&S?(f=A[S],n=o,t=y.map(function(e){return u.isMatch(n,e)}),k=t.indexOf(!0)>-1?a.zonedTimeToUtc(u.parse(n,y[t.indexOf(!0)],new Date),"UTC").toJSON().split("T")[0]:null,x=function(e){var n=p.map(function(n){return u.isMatch(e,n)});if(n.indexOf(!0)>-1){var t=a.zonedTimeToUtc(u.parse(e,p[n.indexOf(!0)],new Date),"UTC");return a.formatInTimeZone(t,"UTC","HH:mm")}return null}(o),w=function(e){var n=!1,t={hours:0,minutes:0},r=new RegExp(/([0-9]+)h([0-9]+)m/),i=new RegExp(/([0-9]+)h/);if(e.match(r)){n=!0;var o=e.match(r),u=o[2];t.hours=parseInt(o[1]),t.minutes=parseInt(u)}else if(e.match(i)){n=!0;var a=e.match(i);t.hours=parseInt(a[1]),t.minutes=0}return n?t:null}(o),k&&(f.date=k),x&&(f.time=x),w&&(f.duration=w),f.content.push(o)):"list"===i.type?((T=A[S]).text=o,T.list=v(i).flat()):"html"===i.type?A[S].content.push(i.html):"code"===i.type?((j=A[S]).lang=i.lang,j.text=o):"heading"===i.type&&i.depth>3?A[S].content.push(i.children[0].value):process.env.DEBUG&&(console.log("unhandled token type"),console.log(i))})});return U&&U.then?U.then(l):l()})}catch(e){return Promise.reject(e)}}});
1
+ !function(e,n){"object"==typeof exports&&"undefined"!=typeof module?module.exports=n(require("unified"),require("remark-parse"),require("remark-gfm"),require("@sindresorhus/slugify"),require("remark-stringify"),require("strip-final-newline"),require("date-fns"),require("date-fns-tz/esm")):"function"==typeof define&&define.amd?define(["unified","remark-parse","remark-gfm","@sindresorhus/slugify","remark-stringify","strip-final-newline","date-fns","date-fns-tz/esm"],n):(e||self).issueFormsBodyParser=n(e.unified,e.remarkParse,e.remarkGfm,e.slugify,e.remarkStringify,e.stripFinalNewline,e.dateFns,e.esm)}(this,function(e,n,t,r,i,o,u,a){function f(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var l=/*#__PURE__*/f(n),s=/*#__PURE__*/f(t),d=/*#__PURE__*/f(r),c=/*#__PURE__*/f(i),h=/*#__PURE__*/f(o);function m(e,n){(null==n||n>e.length)&&(n=e.length);for(var t=0,r=new Array(n);t<n;t++)r[t]=e[t];return r}var y=["yyyy-MM-dd","dd/MM/yyyy","dd/MM/yy","dd-MM-yyyy","dd-MM-yy","dd.MM.yyyy","dd.MM.yy"],p=["HH:mm","HH.mm","hh:mm a","hh:mm A"],v=function e(n){return n.children.map(function(t){var r={};return"list"===t.type?e(n):"listItem"===t.type?(r.checked=t.checked,t.children.map(function(e){if("paragraph"===e.type)return r.text=e.children.map(function(e){return"link"===e.type?(r.link=e.url,"["+e.children[0].value+"]("+e.url+")"):e.value}).filter(function(e){return!!e}).join(""),r}).filter(function(e){return!!e})):void 0}).filter(function(e){return!!e})};function g(e,n,t){if(!e.s){if(t instanceof b){if(!t.s)return void(t.o=g.bind(null,e,n));1&n&&(n=t.s),t=t.v}if(t&&t.then)return void t.then(g.bind(null,e,n),g.bind(null,e,2));e.s=n,e.v=t;var r=e.o;r&&r(e)}}const b=/*#__PURE__*/function(){function e(){}return e.prototype.then=function(n,t){const r=new e,i=this.s;if(i){const e=1&i?n:t;if(e){try{g(r,1,e(this.v))}catch(e){g(r,2,e)}return r}return this}return this.o=function(e){try{const i=e.v;1&e.s?g(r,1,n?n(i):i):t?g(r,1,t(i)):g(r,2,i)}catch(e){g(r,2,e)}},r},e}();function M(e){return e instanceof b&&1&e.s}return function(n){try{var t,r,i,o,f,k,x,w,T,j,q,I,O;return Promise.resolve(e.unified().use(l.default).use(s.default).parse(n)).then(function(n){function l(){for(q in A)(O=(I=A[q]).content.filter(Boolean))&&O.length>0&&(1===O.length&&(I.text=O[0]),I.text=O.join("\n\n")),I.content=O;return A}if(!n)return[];var A={},S=null;t=function(e,n){var t="undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(t)return(t=t.call(e)).next.bind(t);if(Array.isArray(e)||(t=function(e,n){if(e){if("string"==typeof e)return m(e,n);var t=Object.prototype.toString.call(e).slice(8,-1);return"Object"===t&&e.constructor&&(t=e.constructor.name),"Map"===t||"Set"===t?Array.from(e):"Arguments"===t||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t)?m(e,n):void 0}}(e))){t&&(e=t);var r=0;return function(){return r>=e.length?{done:!0}:{done:!1,value:e[r++]}}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}(n.children);var U=function(e,n,t){for(var r;;){var i=e();if(M(i)&&(i=i.v),!i)return o;if(i.then){r=0;break}var o=t();if(o&&o.then){if(!M(o)){r=1;break}o=o.s}}var u=new b,a=g.bind(null,u,2);return(0===r?i.then(l):1===r?o.then(f):(void 0).then(function(){(i=e())?i.then?i.then(l).then(void 0,a):l(i):g(u,1,o)})).then(void 0,a),u;function f(n){o=n;do{if(!(i=e())||M(i)&&!i.v)return void g(u,1,o);if(i.then)return void i.then(l).then(void 0,a);M(o=t())&&(o=o.v)}while(!o||!o.then);o.then(f).then(void 0,a)}function l(e){e?(o=t())&&o.then?o.then(f).then(void 0,a):f(o):g(u,1,o)}}(function(){return!(r=t()).done},0,function(){return i=r.value,Promise.resolve(e.unified().use(s.default).use(c.default).stringify(i)).then(function(e){var n,t;(o=h.default(e)).indexOf("\\_")>-1&&(o=o.replace(/\\_/g,"_")),"heading"===i.type?(S=d.default(i.children[0].value),A[S]={title:i.children[0].value,heading:i.depth,content:[]}):"paragraph"===i.type&&S?(f=A[S],n=o,t=y.map(function(e){return u.isMatch(n,e)}),k=t.indexOf(!0)>-1?a.zonedTimeToUtc(u.parse(n,y[t.indexOf(!0)],new Date),"UTC").toJSON().split("T")[0]:null,x=function(e){var n=p.map(function(n){return u.isMatch(e,n)});if(n.indexOf(!0)>-1){var t=a.zonedTimeToUtc(u.parse(e,p[n.indexOf(!0)],new Date),"UTC");return a.formatInTimeZone(t,"UTC","HH:mm")}return null}(o),w=function(e){var n=!1,t={hours:0,minutes:0},r=new RegExp(/([0-9]+)h([0-9]+)m/),i=new RegExp(/([0-9]+)h/);if(e.match(r)){n=!0;var o=e.match(r),u=o[2];t.hours=parseInt(o[1]),t.minutes=parseInt(u)}else if(e.match(i)){n=!0;var a=e.match(i);t.hours=parseInt(a[1]),t.minutes=0}return n?t:null}(o),k&&(f.date=k),x&&(f.time=x),w&&(f.duration=w),f.content.push(o)):"list"===i.type?((T=A[S]).text=o,T.list=v(i).flat()):"html"===i.type?A[S].content.push(i.html):"code"===i.type?((j=A[S]).lang=i.lang,j.text=o):process.env.DEBUG&&(console.log("unhandled token type"),console.log(i))})});return U&&U.then?U.then(l):l()})}catch(e){return Promise.reject(e)}}});
2
2
  //# sourceMappingURL=parse.umd.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"parse.umd.js","sources":["../src/parsers/date.js","../src/parsers/time.js","../src/parsers/index.js","../src/parsers/list.js","../src/parse.js","../src/parsers/duration.js"],"sourcesContent":["'use strict'\n\nimport { parse, isMatch } from 'date-fns'\nimport { zonedTimeToUtc } from 'date-fns-tz/esm'\n\nconst loc = 'UTC'\nconst commonDateFormats = [\n 'yyyy-MM-dd',\n 'dd/MM/yyyy',\n 'dd/MM/yy',\n 'dd-MM-yyyy',\n 'dd-MM-yy',\n 'dd.MM.yyyy',\n 'dd.MM.yy'\n]\n\nexport default function parseDate(text) {\n const match = commonDateFormats.map((format) => {\n return isMatch(text, format)\n })\n if (match.indexOf(true) > -1) {\n const date = zonedTimeToUtc(\n parse(text, commonDateFormats[match.indexOf(true)], new Date()),\n loc\n ).toJSON()\n return date.split('T')[0]\n } else {\n return null\n }\n}\n","'use strict'\n\nimport { parse, isMatch } from 'date-fns'\nimport { zonedTimeToUtc, formatInTimeZone } from 'date-fns-tz/esm'\n\nconst loc = 'UTC'\nconst commonTimeFormats = ['HH:mm', 'HH.mm', 'hh:mm a', 'hh:mm A']\n\nexport default function parseTime(text) {\n const match = commonTimeFormats.map((format) => {\n return isMatch(text, format)\n })\n if (match.indexOf(true) > -1) {\n const time = zonedTimeToUtc(\n parse(text, commonTimeFormats[match.indexOf(true)], new Date()),\n loc\n )\n return formatInTimeZone(time, loc, 'HH:mm')\n } else {\n return null\n }\n}\n","'use strict'\n\nimport date from './date.js'\nimport time from './time.js'\nimport duration from './duration.js'\nimport list from './list.js'\n\nexport const parseDate = date\nexport const parseTime = time\nexport const parseDuration = duration\nexport const parseList = list\n","'use strict'\n\nexport default function parseList(list) {\n return list.children\n .map((item) => {\n const listItem = {}\n if (item.type === 'list') {\n return parseList(list)\n } else if (item.type === 'listItem') {\n listItem.checked = item.checked\n return item.children\n .map((child) => {\n if (child.type === 'paragraph') {\n listItem.text = child.children\n .map((c) => {\n if (c.type === 'link') {\n return c.children[0].value\n } else {\n return c.value\n }\n })\n .filter((x) => !!x)\n .join('')\n return listItem\n }\n })\n .filter((x) => !!x)\n }\n })\n .filter((x) => !!x)\n}\n","'use strict'\n\nimport { unified } from 'unified'\nimport remarkParse from 'remark-parse'\nimport remarkGfm from 'remark-gfm'\nimport slugify from '@sindresorhus/slugify'\nimport remarkStringify from 'remark-stringify'\nimport stripFinalNewline from 'strip-final-newline'\n\nimport {\n parseDate,\n parseTime,\n parseDuration,\n parseList\n} from './parsers/index.js'\n\nexport default async function parseMD(body) {\n const tokens = await unified().use(remarkParse).use(remarkGfm).parse(body)\n if (!tokens) {\n return []\n }\n\n const structuredResponse = {}\n let currentHeading = null\n for (const token of tokens.children) {\n const text = await unified()\n .use(remarkGfm)\n .use(remarkStringify)\n .stringify(token)\n let cleanText = stripFinalNewline(text)\n\n // remove `\\\\_`\n if (cleanText.indexOf('\\\\_') > -1) {\n cleanText = cleanText.replace(/\\\\_/g, '_')\n }\n\n // issue forms uses h3 as a heading\n if (token.type === 'heading' && token.depth === 3) {\n currentHeading = slugify(token.children[0].value)\n structuredResponse[currentHeading] = {\n title: token.children[0].value,\n content: []\n }\n } else if (token.type === 'paragraph' && currentHeading) {\n const obj = structuredResponse[currentHeading]\n\n const date = parseDate(cleanText)\n const time = parseTime(cleanText)\n const duration = parseDuration(cleanText)\n\n if (date) {\n obj.date = date\n }\n\n if (time) {\n obj.time = time\n }\n\n if (duration) {\n obj.duration = duration\n }\n\n obj.content.push(cleanText)\n } else if (token.type === 'list') {\n const obj = structuredResponse[currentHeading]\n obj.text = cleanText\n obj.list = parseList(token).flat()\n } else if (token.type === 'html') {\n const obj = structuredResponse[currentHeading]\n obj.content.push(token.html)\n } else if (token.type === 'code') {\n const obj = structuredResponse[currentHeading]\n obj.lang = token.lang\n obj.text = cleanText\n } else if (token.type === 'heading' && token.depth > 3) {\n const obj = structuredResponse[currentHeading]\n obj.content.push(token.children[0].value)\n } else {\n if(process.env.DEBUG){\n console.log('unhandled token type')\n console.log(token) \n }\n }\n }\n\n for (const key in structuredResponse) {\n const token = structuredResponse[key]\n const content = token.content.filter(Boolean)\n if (content && content.length > 0) {\n if (content.length === 1) {\n token.text = content[0]\n }\n token.text = content.join('\\n\\n')\n }\n token.content = content\n }\n\n return structuredResponse\n}\n","'use strict'\n\nexport default function parseDuration(text) {\n let matched = false\n const duration = {\n hours: 0,\n minutes: 0\n }\n\n const hoursAndMinutes = new RegExp(/([0-9]+)h([0-9]+)m/)\n const hours = new RegExp(/([0-9]+)h/)\n\n if (text.match(hoursAndMinutes)) {\n matched = true\n const [, h, m] = text.match(hoursAndMinutes)\n duration.hours = parseInt(h)\n duration.minutes = parseInt(m)\n } else if (text.match(hours)) {\n matched = true\n const [, h] = text.match(hours)\n duration.hours = parseInt(h)\n duration.minutes = 0\n }\n\n if (matched) {\n return duration\n } else {\n return null\n }\n}\n"],"names":["commonDateFormats","commonTimeFormats","parseList","list","children","map","item","listItem","type","checked","child","text","c","value","filter","x","join","_settle","pact","state","s","_Pact","o","bind","v","then","observer","prototype","onFulfilled","onRejected","result","this","callback","e","_this","_isSettledPact","thenable","body","token","cleanText","obj","date","time","duration","key","content","unified","use","remarkParse","remarkGfm","parse","tokens","_temp2","structuredResponse","Boolean","length","currentHeading","_iterator","_createForOfIteratorHelperLoose","_temp","test","update","stage","shouldContinue","reject","_resumeAfterTest","_resumeAfterBody","updateValue","_for","_step","done","Promise","resolve","remarkStringify","stringify","_unified$use$use$stri","match","stripFinalNewline","indexOf","replace","depth","slugify","title","format","isMatch","zonedTimeToUtc","Date","toJSON","split","parseTime","formatInTimeZone","matched","hours","minutes","hoursAndMinutes","RegExp","_text$match","m","parseInt","parseDuration","push","flat","html","lang","process","env","DEBUG","console","log"],"mappings":"o8BAKA,IACMA,EAAoB,CACxB,aACA,aACA,WACA,aACA,WACA,aACA,YCPIC,EAAoB,CAAC,QAAS,QAAS,UAAW,WCI3CC,ECRWA,SAAAA,EAAUC,GAChC,OAAOA,EAAKC,SACTC,IAAI,SAACC,GACJ,IAAMC,EAAW,CAAjB,EACA,MAAkB,SAAdD,EAAKE,KACAN,EAAUC,GACM,aAAdG,EAAKE,MACdD,EAASE,QAAUH,EAAKG,QACjBH,EAAKF,SACTC,IAAI,SAACK,GACJ,GAAmB,cAAfA,EAAMF,KAWR,OAVAD,EAASI,KAAOD,EAAMN,SACnBC,IAAI,SAACO,GACJ,MAAe,SAAXA,EAAEJ,KACGI,EAAER,SAAS,GAAGS,MAEdD,EAAEC,KAEZ,GACAC,OAAO,SAACC,GAAD,QAASA,CAAT,GACPC,KAAK,IACDT,CAEV,GACAO,OAAO,SAACC,GAAD,QAASA,CAAT,SAlBDT,CAoBZ,GACAQ,OAAO,SAACC,GAAD,QAASA,CAAT,EACX,ECSM,SAASE,EAAQC,EAAMC,EAAON,GACpC,IAAKK,EAAKE,EAAG,CACZ,GAAIP,aAAiBQ,EAAO,CAC3B,IAAIR,EAAMO,EAOT,YADAP,EAAMS,EAAIL,EAAQM,KAAK,KAAML,EAAMC,IALvB,EAARA,IACHA,EAAQN,EAAMO,GAEfP,EAAQA,EAAMW,CAKf,CACD,GAAIX,GAASA,EAAMY,KAElB,YADAZ,EAAMY,KAAKR,EAAQM,KAAK,KAAML,EAAMC,GAAQF,EAAQM,KAAK,KAAML,EAAM,IAGtEA,EAAKE,EAAID,EACTD,EAAKM,EAAIX,EACT,IAAMa,EAAWR,EAAKI,EAClBI,GACHA,EAASR,EAEV,CACD,CA9DM,MAAMG,eAAsB,WAClC,SAAiBA,IAAA,CAiCjB,OAhCAA,EAAMM,UAAUF,KAAO,SAASG,EAAaC,GAC5C,MAAMC,EAAS,IAAfT,EACMF,EAAQY,KAAKX,EACnB,GAAID,EAAO,CACV,MAAMa,EAAmB,EAARb,EAAYS,EAAcC,EAC3C,GAAIG,EAAU,CACb,IACCf,EAAQa,EAAQ,EAAGE,EAASD,KAAKP,GAGjC,CAFC,MAAOS,GACRhB,EAAQa,EAAQ,EAAGG,EACnB,CACD,OAAOH,CACP,CACA,OAAOC,IAER,CAeD,OAdAA,KAAKT,EAAI,SAASY,GACjB,IACC,MAAMrB,EAAQqB,EAAMV,EACN,EAAVU,EAAMd,EACTH,EAAQa,EAAQ,EAAGF,EAAcA,EAAYf,GAASA,GAC5CgB,EACVZ,EAAQa,EAAQ,EAAGD,EAAWhB,IAE9BI,EAAQa,EAAQ,EAAGjB,EAIpB,CAFC,MAAOoB,GACRhB,EAAQa,EAAQ,EAAGG,EACnB,CACD,EACMH,CACP,GAED,CAnCkC,GAgE5B,SAAAK,EAAwBC,GAC9B,OAAOA,aAAAf,GAA0C,EAAbe,EAAShB,CAC7C,iBAnDqCiB,eAQzBC,EAKLC,EAeIC,EAEAC,EACAC,EACAC,EAgBAH,EAOAA,EAcCI,EACHN,EACAO,EAtEaC,OAAAA,QAAAA,QAAAA,EAAOA,UAAGC,IAAIC,WAAaD,IAAIE,WAAWC,MAAMb,kBAA/Dc,GADoC,SAAAC,IAqE1C,IAAWR,KAAOS,GAEVR,GADAP,EAAQe,EAAmBT,IACXC,QAAQ/B,OAAOwC,WACtBT,EAAQU,OAAS,IACP,IAAnBV,EAAQU,SACVjB,EAAM3B,KAAOkC,EAAQ,IAEvBP,EAAM3B,KAAOkC,EAAQ7B,KAAK,SAE5BsB,EAAMO,QAAUA,EAGlB,OAAOQ,CAjFmC,CAE1C,IAAKF,EACH,MAAO,GAGT,IAAME,EAAqB,CAAA,EACvBG,EAAiB,KAPqBC,2qBAAAC,CAQtBP,EAAO/C,UAAU,IAAAuD,EAuOhC,SAAcC,EAAMC,EAAQxB,GAElC,IADA,IAAIyB,IACK,CACR,IAAIC,EAAiBH,IAIrB,GAHIzB,EAAe4B,KAClBA,EAAiBA,EAAevC,IAE5BuC,EACJ,OAAOjC,EAER,GAAIiC,EAAetC,KAAM,CACxBqC,EAAQ,EACR,KACA,CACD,IAAIhC,EAASO,IACb,GAAIP,GAAUA,EAAOL,KAAM,CAC1B,IAAIU,EAAeL,GAEZ,CACNgC,EAAQ,EACR,KACA,CAJAhC,EAASA,EAAOV,CAKjB,CAQD,CACD,IAAIF,EAAO,IAAXG,EACI2C,EAAS/C,EAAQM,KAAK,KAAML,EAAM,GAEtC,OADW,IAAV4C,EAAcC,EAAetC,KAAKwC,GAA8B,IAAVH,EAAchC,EAAOL,KAAKyC,SAT3EC,GAS2G1C,KAwCjH,YACKsC,EAAiBH,KAChBG,EAAetC,KAClBsC,EAAetC,KAAKwC,GAAkBxC,UAAK,EAAQuC,GAEnDC,EAAiBF,GAGlB9C,EAAQC,EAAM,EAAGY,EAElB,IAlD0IL,UAAK,EAAQuC,GACjJ9C,EACP,SAASgD,EAAiBrD,GACzBiB,EAASjB,EACT,EAAG,CASF,KADAkD,EAAiBH,MACOzB,EAAe4B,KAAoBA,EAAevC,EAEzE,YADAP,EAAQC,EAAM,EAAGY,GAGlB,GAAIiC,EAAetC,KAElB,YADAsC,EAAetC,KAAKwC,GAAkBxC,UAAK,EAAQuC,GAIhD7B,EADJL,EAASO,OAERP,EAASA,EAAON,EAEjB,QAASM,IAAWA,EAAOL,MAC5BK,EAAOL,KAAKyC,GAAkBzC,UAAK,EAAQuC,EAC3C,CACD,SAASC,EAAiBF,GACrBA,GACHjC,EAASO,MACKP,EAAOL,KACpBK,EAAOL,KAAKyC,GAAkBzC,UAAK,EAAQuC,GAE3CE,EAAiBpC,GAGlBb,EAAQC,EAAM,EAAGY,EAElB,CAYD,CA3TsCsC,CAAA,WAAA,QAAAC,EAAAZ,KAAAa,IAAA,EAAA,EAAA,WAAA,OAA1BhC,EAA0B+B,EAAAxD,MAAA0D,QAAAC,QAChB1B,EAAOA,UACvBC,IAAIE,EADY,SAEhBF,IAAI0B,EAFY,SAGhBC,UAAUpC,IAJsBb,KAAA,SAAAkD,GJRxB,IAAmBhE,EAC1BiE,GIYArC,EAAYsC,EAAiB,QAA7BtC,IAGUuC,QAAQ,QAAU,IAC9BvC,EAAYA,EAAUwC,QAAQ,OAAQ,MAIrB,YAAfzC,EAAM9B,MAAsC,IAAhB8B,EAAM0C,OACpCxB,EAAiByB,EAAAA,QAAQ3C,EAAMlC,SAAS,GAAGS,OAC3CwC,EAAmBG,GAAkB,CACnC0B,MAAO5C,EAAMlC,SAAS,GAAGS,MACzBgC,QAAS,KAEa,cAAfP,EAAM9B,MAAwBgD,GACjChB,EAAMa,EAAmBG,GJ5BH7C,EI8BL4B,EJ7BrBqC,EAAQ5E,EAAkBK,IAAI,SAAC8E,GACnC,OAAOC,EAAAA,QAAQzE,EAAMwE,EACtB,GI2BS1C,EJ1BNmC,EAAME,SAAQ,IAAS,EACZO,EAAAA,eACXnC,EAAKA,MAACvC,EAAMX,EAAkB4E,EAAME,SAAQ,IAAQ,IAAIQ,MAjBlD,OAmBNC,SACUC,MAAM,KAAK,QIsBf9C,EHvCY+C,SAAU9E,GAChC,IAAMiE,EAAQ3E,EAAkBI,IAAI,SAAC8E,GACnC,OAAOC,UAAQzE,EAAMwE,EACtB,GACD,GAAIP,EAAME,SAAQ,IAAS,EAAG,CAC5B,IAAMpC,EAAO2C,EAAAA,eACXnC,EAAKA,MAACvC,EAAMV,EAAkB2E,EAAME,SAAQ,IAAQ,IAAIQ,MATlD,OAYR,OAAOI,EAAgBA,iBAAChD,EAZhB,MAY2B,QACpC,CACC,OAAO,IAEV,CG0BkB+C,CAAUlD,GACjBI,EC9CG,SAAuBhC,GACpC,IAAIgF,GAAU,EACRhD,EAAW,CACfiD,MAAO,EACPC,QAAS,GAGLC,EAAkB,IAAIC,OAAO,sBAC7BH,EAAQ,IAAIG,OAAO,aAEzB,GAAIpF,EAAKiE,MAAMkB,GAAkB,CAC/BH,GAAU,EACV,IAAAK,EAAiBrF,EAAKiE,MAAMkB,GAAhBG,EACZtD,EAAAA,GAAAA,EAASiD,MAAQM,SADLD,EAAAA,IAEZtD,EAASkD,QAAUK,SAASD,EAC7B,MAAUtF,GAAAA,EAAKiE,MAAMgB,GAAQ,CAC5BD,GAAU,EACV,IAAchF,EAAAA,EAAKiE,MAAMgB,GACzBjD,EAASiD,MAAQM,SAAjBvD,EAAAA,IACAA,EAASkD,QAAU,CACpB,CAED,OAAIF,EACKhD,MAIV,CDmBsBwD,CAAc5D,GAE3BE,IACFD,EAAIC,KAAOA,GAGTC,IACFF,EAAIE,KAAOA,GAGTC,IACFH,EAAIG,SAAWA,GAGjBH,EAAIK,QAAQuD,KAAK7D,IACO,SAAfD,EAAM9B,OACTgC,EAAMa,EAAmBG,IAC3B7C,KAAO4B,EACXC,EAAIrC,KAAOD,EAAUoC,GAAO+D,QACJ,SAAf/D,EAAM9B,KACH6C,EAAmBG,GAC3BX,QAAQuD,KAAK9D,EAAMgE,MACC,SAAfhE,EAAM9B,OACTgC,EAAMa,EAAmBG,IAC3B+C,KAAOjE,EAAMiE,KACjB/D,EAAI7B,KAAO4B,GACa,YAAfD,EAAM9B,MAAsB8B,EAAM0C,MAAQ,EACvC3B,EAAmBG,GAC3BX,QAAQuD,KAAK9D,EAAMlC,SAAS,GAAGS,OAEhC2F,QAAQC,IAAIC,QACbC,QAAQC,IAAI,wBACZD,QAAQC,IAAItE,GAxDmB,EA2DpC"}
1
+ {"version":3,"file":"parse.umd.js","sources":["../src/parsers/date.js","../src/parsers/time.js","../src/parsers/index.js","../src/parsers/list.js","../src/parse.js","../src/parsers/duration.js"],"sourcesContent":["'use strict'\n\nimport { parse, isMatch } from 'date-fns'\nimport { zonedTimeToUtc } from 'date-fns-tz/esm'\n\nconst loc = 'UTC'\nconst commonDateFormats = [\n 'yyyy-MM-dd',\n 'dd/MM/yyyy',\n 'dd/MM/yy',\n 'dd-MM-yyyy',\n 'dd-MM-yy',\n 'dd.MM.yyyy',\n 'dd.MM.yy'\n]\n\nexport default function parseDate(text) {\n const match = commonDateFormats.map((format) => {\n return isMatch(text, format)\n })\n if (match.indexOf(true) > -1) {\n const date = zonedTimeToUtc(\n parse(text, commonDateFormats[match.indexOf(true)], new Date()),\n loc\n ).toJSON()\n return date.split('T')[0]\n } else {\n return null\n }\n}\n","'use strict'\n\nimport { parse, isMatch } from 'date-fns'\nimport { zonedTimeToUtc, formatInTimeZone } from 'date-fns-tz/esm'\n\nconst loc = 'UTC'\nconst commonTimeFormats = ['HH:mm', 'HH.mm', 'hh:mm a', 'hh:mm A']\n\nexport default function parseTime(text) {\n const match = commonTimeFormats.map((format) => {\n return isMatch(text, format)\n })\n if (match.indexOf(true) > -1) {\n const time = zonedTimeToUtc(\n parse(text, commonTimeFormats[match.indexOf(true)], new Date()),\n loc\n )\n return formatInTimeZone(time, loc, 'HH:mm')\n } else {\n return null\n }\n}\n","'use strict'\n\nimport date from './date.js'\nimport time from './time.js'\nimport duration from './duration.js'\nimport list from './list.js'\n\nexport const parseDate = date\nexport const parseTime = time\nexport const parseDuration = duration\nexport const parseList = list\n","'use strict'\n\nexport default function parseList(list) {\n return list.children\n .map((item) => {\n const listItem = {}\n if (item.type === 'list') {\n return parseList(list)\n } else if (item.type === 'listItem') {\n listItem.checked = item.checked\n return item.children\n .map((child) => {\n if (child.type === 'paragraph') {\n listItem.text = child.children\n .map((c) => {\n if (c.type === 'link') {\n listItem.link = c.url\n return `[${c.children[0].value}](${c.url})`\n } else {\n return c.value\n }\n })\n .filter((x) => !!x)\n .join('')\n return listItem\n }\n })\n .filter((x) => !!x)\n }\n })\n .filter((x) => !!x)\n}\n","'use strict'\n\nimport { unified } from 'unified'\nimport remarkParse from 'remark-parse'\nimport remarkGfm from 'remark-gfm'\nimport slugify from '@sindresorhus/slugify'\nimport remarkStringify from 'remark-stringify'\nimport stripFinalNewline from 'strip-final-newline'\n\nimport {\n parseDate,\n parseTime,\n parseDuration,\n parseList\n} from './parsers/index.js'\n\nexport default async function parseMD(body) {\n const tokens = await unified().use(remarkParse).use(remarkGfm).parse(body)\n if (!tokens) {\n return []\n }\n\n const structuredResponse = {}\n let currentHeading = null\n for (const token of tokens.children) {\n const text = await unified()\n .use(remarkGfm)\n .use(remarkStringify)\n .stringify(token)\n let cleanText = stripFinalNewline(text)\n\n // remove `\\\\_`\n if (cleanText.indexOf('\\\\_') > -1) {\n cleanText = cleanText.replace(/\\\\_/g, '_')\n }\n\n // issue forms uses h3 as a heading\n if (token.type === 'heading') {\n currentHeading = slugify(token.children[0].value)\n structuredResponse[currentHeading] = {\n title: token.children[0].value,\n heading: token.depth,\n content: []\n }\n } else if (token.type === 'paragraph' && currentHeading) {\n const obj = structuredResponse[currentHeading]\n\n const date = parseDate(cleanText)\n const time = parseTime(cleanText)\n const duration = parseDuration(cleanText)\n\n if (date) {\n obj.date = date\n }\n\n if (time) {\n obj.time = time\n }\n\n if (duration) {\n obj.duration = duration\n }\n\n obj.content.push(cleanText)\n } else if (token.type === 'list') {\n const obj = structuredResponse[currentHeading]\n obj.text = cleanText\n obj.list = parseList(token).flat()\n } else if (token.type === 'html') {\n const obj = structuredResponse[currentHeading]\n obj.content.push(token.html)\n } else if (token.type === 'code') {\n const obj = structuredResponse[currentHeading]\n obj.lang = token.lang\n obj.text = cleanText\n } else {\n if (process.env.DEBUG) {\n console.log('unhandled token type')\n console.log(token)\n }\n }\n }\n\n for (const key in structuredResponse) {\n const token = structuredResponse[key]\n const content = token.content.filter(Boolean)\n if (content && content.length > 0) {\n if (content.length === 1) {\n token.text = content[0]\n }\n token.text = content.join('\\n\\n')\n }\n token.content = content\n }\n\n return structuredResponse\n}\n","'use strict'\n\nexport default function parseDuration(text) {\n let matched = false\n const duration = {\n hours: 0,\n minutes: 0\n }\n\n const hoursAndMinutes = new RegExp(/([0-9]+)h([0-9]+)m/)\n const hours = new RegExp(/([0-9]+)h/)\n\n if (text.match(hoursAndMinutes)) {\n matched = true\n const [, h, m] = text.match(hoursAndMinutes)\n duration.hours = parseInt(h)\n duration.minutes = parseInt(m)\n } else if (text.match(hours)) {\n matched = true\n const [, h] = text.match(hours)\n duration.hours = parseInt(h)\n duration.minutes = 0\n }\n\n if (matched) {\n return duration\n } else {\n return null\n }\n}\n"],"names":["commonDateFormats","commonTimeFormats","parseList","list","children","map","item","listItem","type","checked","child","text","c","link","url","value","filter","x","join","_settle","pact","state","s","_Pact","o","bind","v","then","observer","prototype","onFulfilled","onRejected","result","this","callback","e","_this","thenable","body","token","cleanText","obj","date","time","duration","key","content","unified","use","remarkParse","remarkGfm","parse","tokens","_temp2","structuredResponse","Boolean","length","currentHeading","_iterator","test","update","stage","shouldContinue","_isSettledPact","reject","_resumeAfterTest","_resumeAfterBody","updateValue","remarkStringify","stringify","match","stripFinalNewline","indexOf","replace","slugify","title","heading","depth","format","isMatch","zonedTimeToUtc","Date","toJSON","split","parseTime","formatInTimeZone","matched","hours","minutes","hoursAndMinutes","RegExp","_text$match","m","parseInt","parseDuration","push","flat","html","lang","process","env","DEBUG","console","log"],"mappings":"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"}
package/src/index.js CHANGED
@@ -7,8 +7,14 @@ import parse from './parse.js'
7
7
  async function run() {
8
8
  core.info('Parsing issue body ...')
9
9
 
10
+ let content = core.getInput('body')
11
+
12
+ if (content === '' && Object.hasOwn(github.context.payload, 'issue')) {
13
+ content = github.context.payload.issue.body
14
+ }
15
+
10
16
  try {
11
- const parsedContent = await parse(github.context.payload.issue.body)
17
+ const parsedContent = await parse(content)
12
18
 
13
19
  if (parsedContent !== undefined) {
14
20
  core.setOutput('data', parsedContent)
package/src/parse.js CHANGED
@@ -35,10 +35,11 @@ export default async function parseMD(body) {
35
35
  }
36
36
 
37
37
  // issue forms uses h3 as a heading
38
- if (token.type === 'heading' && token.depth === 3) {
38
+ if (token.type === 'heading') {
39
39
  currentHeading = slugify(token.children[0].value)
40
40
  structuredResponse[currentHeading] = {
41
41
  title: token.children[0].value,
42
+ heading: token.depth,
42
43
  content: []
43
44
  }
44
45
  } else if (token.type === 'paragraph' && currentHeading) {
@@ -72,13 +73,10 @@ export default async function parseMD(body) {
72
73
  const obj = structuredResponse[currentHeading]
73
74
  obj.lang = token.lang
74
75
  obj.text = cleanText
75
- } else if (token.type === 'heading' && token.depth > 3) {
76
- const obj = structuredResponse[currentHeading]
77
- obj.content.push(token.children[0].value)
78
76
  } else {
79
- if(process.env.DEBUG){
77
+ if (process.env.DEBUG) {
80
78
  console.log('unhandled token type')
81
- console.log(token)
79
+ console.log(token)
82
80
  }
83
81
  }
84
82
  }
@@ -14,7 +14,8 @@ export default function parseList(list) {
14
14
  listItem.text = child.children
15
15
  .map((c) => {
16
16
  if (c.type === 'link') {
17
- return c.children[0].value
17
+ listItem.link = c.url
18
+ return `[${c.children[0].value}](${c.url})`
18
19
  } else {
19
20
  return c.value
20
21
  }
@@ -1 +0,0 @@
1
- {"parent":null,"pid":1747,"argv":["/usr/local/bin/node","/home/runner/work/issue-forms-body-parser/issue-forms-body-parser/node_modules/.bin/tap","--node-arg=--experimental-json-modules","--test-env=GITHUB_REPOSITORY=zentered/issue-forms-body-parser-test","-J","test/parse-issue.test.js"],"execArgv":[],"cwd":"/home/runner/work/issue-forms-body-parser/issue-forms-body-parser","time":1665736075235,"ppid":1736,"coverageFilename":"/home/runner/work/issue-forms-body-parser/issue-forms-body-parser/.nyc_output/488cf9e0-2479-4d98-9daa-e56e51a96d7f.json","externalId":"","uuid":"488cf9e0-2479-4d98-9daa-e56e51a96d7f","files":[]}
@@ -1 +0,0 @@
1
- {"parent":"488cf9e0-2479-4d98-9daa-e56e51a96d7f","pid":1758,"argv":["/usr/local/bin/node","/home/runner/work/issue-forms-body-parser/issue-forms-body-parser/test/parse-issue.test.js"],"execArgv":["--experimental-json-modules"],"cwd":"/home/runner/work/issue-forms-body-parser/issue-forms-body-parser","time":1665736075608,"ppid":1747,"coverageFilename":"/home/runner/work/issue-forms-body-parser/issue-forms-body-parser/.nyc_output/506035e5-5150-4257-b8c2-9b0d5c9c3315.json","externalId":"test/parse-issue.test.js","uuid":"506035e5-5150-4257-b8c2-9b0d5c9c3315","files":[]}