create-nextjs-cms 0.5.55 → 0.5.58
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +4 -4
- package/templates/default/CHANGELOG.md +140 -140
- package/templates/default/_gitignore +1 -0
- package/templates/default/app/(auth)/auth/login/LoginPage.tsx +14 -11
- package/templates/default/app/(rootLayout)/admins/page.tsx +7 -2
- package/templates/default/app/(rootLayout)/advanced/page.tsx +8 -2
- package/templates/default/app/(rootLayout)/browse/[section]/[page]/page.tsx +17 -3
- package/templates/default/app/(rootLayout)/categorized/[section]/page.tsx +9 -1
- package/templates/default/app/(rootLayout)/dashboard-new/page.tsx +7 -0
- package/templates/default/app/(rootLayout)/edit/[section]/[itemId]/page.tsx +11 -1
- package/templates/default/app/(rootLayout)/layout.tsx +8 -1
- package/templates/default/app/(rootLayout)/new/[section]/page.tsx +9 -1
- package/templates/default/app/(rootLayout)/section/[section]/page.tsx +10 -1
- package/templates/default/app/(rootLayout)/settings/page.tsx +7 -1
- package/templates/default/app/api/trpc/[trpc]/route.ts +1 -1
- package/templates/default/app/api/video/route.ts +1 -1
- package/templates/default/app/layout.tsx +5 -3
- package/templates/default/app/providers.tsx +10 -9
- package/templates/default/apps/cms/node_modules/next/node_modules/_tmp_40516_de1b9f7e36eccb968b79dbd2b8c388ea/LICENSE +191 -0
- package/templates/default/apps/cms/node_modules/next/node_modules/_tmp_40516_de1b9f7e36eccb968b79dbd2b8c388ea/README.md +118 -0
- package/templates/default/apps/cms/node_modules/next/node_modules/_tmp_40516_de1b9f7e36eccb968b79dbd2b8c388ea/install/build.js +38 -0
- package/templates/default/apps/cms/node_modules/next/node_modules/_tmp_40516_de1b9f7e36eccb968b79dbd2b8c388ea/install/check.js +14 -0
- package/templates/default/apps/cms/node_modules/next/node_modules/_tmp_40516_de1b9f7e36eccb968b79dbd2b8c388ea/lib/channel.js +177 -0
- package/templates/default/apps/cms/node_modules/next/node_modules/_tmp_40516_de1b9f7e36eccb968b79dbd2b8c388ea/lib/colour.js +195 -0
- package/templates/default/apps/cms/node_modules/next/node_modules/_tmp_40516_de1b9f7e36eccb968b79dbd2b8c388ea/lib/composite.js +212 -0
- package/templates/default/apps/cms/node_modules/next/node_modules/_tmp_40516_de1b9f7e36eccb968b79dbd2b8c388ea/lib/constructor.js +499 -0
- package/templates/default/apps/cms/node_modules/next/node_modules/_tmp_40516_de1b9f7e36eccb968b79dbd2b8c388ea/lib/index.d.ts +1971 -0
- package/templates/default/apps/cms/node_modules/next/node_modules/_tmp_40516_de1b9f7e36eccb968b79dbd2b8c388ea/lib/index.js +16 -0
- package/templates/default/apps/cms/node_modules/next/node_modules/_tmp_40516_de1b9f7e36eccb968b79dbd2b8c388ea/lib/input.js +809 -0
- package/templates/default/apps/cms/node_modules/next/node_modules/_tmp_40516_de1b9f7e36eccb968b79dbd2b8c388ea/lib/is.js +143 -0
- package/templates/default/apps/cms/node_modules/next/node_modules/_tmp_40516_de1b9f7e36eccb968b79dbd2b8c388ea/lib/libvips.js +207 -0
- package/templates/default/apps/cms/node_modules/next/node_modules/_tmp_40516_de1b9f7e36eccb968b79dbd2b8c388ea/lib/operation.js +1016 -0
- package/templates/default/apps/cms/node_modules/next/node_modules/_tmp_40516_de1b9f7e36eccb968b79dbd2b8c388ea/lib/output.js +1666 -0
- package/templates/default/apps/cms/node_modules/next/node_modules/_tmp_40516_de1b9f7e36eccb968b79dbd2b8c388ea/lib/resize.js +595 -0
- package/templates/default/apps/cms/node_modules/next/node_modules/_tmp_40516_de1b9f7e36eccb968b79dbd2b8c388ea/lib/sharp.js +121 -0
- package/templates/default/apps/cms/node_modules/next/node_modules/_tmp_40516_de1b9f7e36eccb968b79dbd2b8c388ea/lib/utility.js +291 -0
- package/templates/default/apps/cms/node_modules/next/node_modules/_tmp_40516_de1b9f7e36eccb968b79dbd2b8c388ea/package.json +202 -0
- package/templates/default/apps/cms/node_modules/next/node_modules/_tmp_40516_de1b9f7e36eccb968b79dbd2b8c388ea/src/binding.gyp +298 -0
- package/templates/default/apps/cms/node_modules/next/node_modules/_tmp_40516_de1b9f7e36eccb968b79dbd2b8c388ea/src/common.cc +1130 -0
- package/templates/default/apps/cms/node_modules/next/node_modules/_tmp_40516_de1b9f7e36eccb968b79dbd2b8c388ea/src/common.h +402 -0
- package/templates/default/apps/cms/node_modules/next/node_modules/_tmp_40516_de1b9f7e36eccb968b79dbd2b8c388ea/src/metadata.cc +346 -0
- package/templates/default/apps/cms/node_modules/next/node_modules/_tmp_40516_de1b9f7e36eccb968b79dbd2b8c388ea/src/metadata.h +90 -0
- package/templates/default/apps/cms/node_modules/next/node_modules/_tmp_40516_de1b9f7e36eccb968b79dbd2b8c388ea/src/operations.cc +499 -0
- package/templates/default/apps/cms/node_modules/next/node_modules/_tmp_40516_de1b9f7e36eccb968b79dbd2b8c388ea/src/operations.h +137 -0
- package/templates/default/apps/cms/node_modules/next/node_modules/_tmp_40516_de1b9f7e36eccb968b79dbd2b8c388ea/src/pipeline.cc +1814 -0
- package/templates/default/apps/cms/node_modules/next/node_modules/_tmp_40516_de1b9f7e36eccb968b79dbd2b8c388ea/src/pipeline.h +408 -0
- package/templates/default/apps/cms/node_modules/next/node_modules/_tmp_40516_de1b9f7e36eccb968b79dbd2b8c388ea/src/sharp.cc +43 -0
- package/templates/default/apps/cms/node_modules/next/node_modules/_tmp_40516_de1b9f7e36eccb968b79dbd2b8c388ea/src/stats.cc +186 -0
- package/templates/default/apps/cms/node_modules/next/node_modules/_tmp_40516_de1b9f7e36eccb968b79dbd2b8c388ea/src/stats.h +62 -0
- package/templates/default/apps/cms/node_modules/next/node_modules/_tmp_40516_de1b9f7e36eccb968b79dbd2b8c388ea/src/utilities.cc +288 -0
- package/templates/default/apps/cms/node_modules/next/node_modules/_tmp_40516_de1b9f7e36eccb968b79dbd2b8c388ea/src/utilities.h +22 -0
- package/templates/default/components/BrowsePage.tsx +4 -4
- package/templates/default/components/DashboardNewPage.tsx +252 -0
- package/templates/default/components/Layout.tsx +2 -2
- package/templates/default/components/LogPage.tsx +2 -3
- package/templates/default/components/NavbarAlt.tsx +5 -5
- package/templates/default/components/SettingsPage.tsx +1 -1
- package/templates/default/components/Sidebar.tsx +7 -7
- package/templates/default/components/form/Form.tsx +5 -5
- package/templates/default/components/form/helpers/util.ts +5 -5
- package/templates/default/dynamic-schemas/schema.ts +381 -381
- package/templates/default/next-env.d.ts +1 -1
- package/templates/default/next.config.ts +24 -0
- package/templates/default/package.json +23 -17
- package/templates/default/{middleware.ts → proxy.ts} +3 -4
- package/templates/default/test/prize.section.ts +58 -0
- package/templates/default/tsconfig.json +6 -3
- package/templates/default/app/api/placeholder/route.ts +0 -7
- package/templates/default/components/form/helpers/_section-hot-reload.js +0 -11
- package/templates/default/public/tinymce/CHANGELOG.md +0 -3940
- package/templates/default/public/tinymce/README.md +0 -77
- package/templates/default/public/tinymce/bower.json +0 -27
- package/templates/default/public/tinymce/composer.json +0 -52
- package/templates/default/public/tinymce/icons/default/icons.js +0 -239
- package/templates/default/public/tinymce/icons/default/icons.min.js +0 -1
- package/templates/default/public/tinymce/icons/default/index.js +0 -7
- package/templates/default/public/tinymce/license.md +0 -9
- package/templates/default/public/tinymce/models/dom/index.js +0 -7
- package/templates/default/public/tinymce/models/dom/model.js +0 -8980
- package/templates/default/public/tinymce/models/dom/model.min.js +0 -1
- package/templates/default/public/tinymce/notices.txt +0 -21
- package/templates/default/public/tinymce/package.json +0 -32
- package/templates/default/public/tinymce/plugins/accordion/index.js +0 -7
- package/templates/default/public/tinymce/plugins/accordion/plugin.js +0 -1373
- package/templates/default/public/tinymce/plugins/accordion/plugin.min.js +0 -1
- package/templates/default/public/tinymce/plugins/advlist/index.js +0 -7
- package/templates/default/public/tinymce/plugins/advlist/plugin.js +0 -473
- package/templates/default/public/tinymce/plugins/advlist/plugin.min.js +0 -1
- package/templates/default/public/tinymce/plugins/anchor/index.js +0 -7
- package/templates/default/public/tinymce/plugins/anchor/plugin.js +0 -237
- package/templates/default/public/tinymce/plugins/anchor/plugin.min.js +0 -1
- package/templates/default/public/tinymce/plugins/autolink/index.js +0 -7
- package/templates/default/public/tinymce/plugins/autolink/plugin.js +0 -315
- package/templates/default/public/tinymce/plugins/autolink/plugin.min.js +0 -1
- package/templates/default/public/tinymce/plugins/autoresize/index.js +0 -7
- package/templates/default/public/tinymce/plugins/autoresize/plugin.js +0 -221
- package/templates/default/public/tinymce/plugins/autoresize/plugin.min.js +0 -1
- package/templates/default/public/tinymce/plugins/autosave/index.js +0 -7
- package/templates/default/public/tinymce/plugins/autosave/plugin.js +0 -249
- package/templates/default/public/tinymce/plugins/autosave/plugin.min.js +0 -1
- package/templates/default/public/tinymce/plugins/charmap/index.js +0 -7
- package/templates/default/public/tinymce/plugins/charmap/plugin.js +0 -997
- package/templates/default/public/tinymce/plugins/charmap/plugin.min.js +0 -1
- package/templates/default/public/tinymce/plugins/code/index.js +0 -7
- package/templates/default/public/tinymce/plugins/code/plugin.js +0 -98
- package/templates/default/public/tinymce/plugins/code/plugin.min.js +0 -1
- package/templates/default/public/tinymce/plugins/codesample/index.js +0 -7
- package/templates/default/public/tinymce/plugins/codesample/plugin.js +0 -3655
- package/templates/default/public/tinymce/plugins/codesample/plugin.min.js +0 -9
- package/templates/default/public/tinymce/plugins/directionality/index.js +0 -7
- package/templates/default/public/tinymce/plugins/directionality/plugin.js +0 -634
- package/templates/default/public/tinymce/plugins/directionality/plugin.min.js +0 -1
- package/templates/default/public/tinymce/plugins/emoticons/index.js +0 -7
- package/templates/default/public/tinymce/plugins/emoticons/js/emojiimages.js +0 -1
- package/templates/default/public/tinymce/plugins/emoticons/js/emojiimages.min.js +0 -1
- package/templates/default/public/tinymce/plugins/emoticons/js/emojis.js +0 -1
- package/templates/default/public/tinymce/plugins/emoticons/js/emojis.min.js +0 -1
- package/templates/default/public/tinymce/plugins/emoticons/plugin.js +0 -809
- package/templates/default/public/tinymce/plugins/emoticons/plugin.min.js +0 -1
- package/templates/default/public/tinymce/plugins/fullscreen/index.js +0 -7
- package/templates/default/public/tinymce/plugins/fullscreen/plugin.js +0 -1607
- package/templates/default/public/tinymce/plugins/fullscreen/plugin.min.js +0 -1
- package/templates/default/public/tinymce/plugins/help/index.js +0 -7
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/ar.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/bg-BG.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/bg_BG.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/ca.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/cs.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/da.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/de.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/el.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/en.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/es.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/eu.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/fa.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/fi.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/fr-FR.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/fr_FR.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/he-IL.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/he_IL.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/hi.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/hr.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/hu-HU.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/hu_HU.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/id.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/it.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/ja.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/kk.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/ko-KR.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/ko_KR.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/ms.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/nb-NO.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/nb_NO.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/nl.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/pl.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/pt-BR.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/pt-PT.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/pt_BR.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/pt_PT.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/ro.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/ru.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/sk.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/sl-SI.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/sl_SI.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/sv-SE.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/sv_SE.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/th-TH.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/th_TH.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/tr.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/uk.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/vi.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/zh-CN.js +0 -87
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/zh-TW.js +0 -93
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/zh_CN.js +0 -87
- package/templates/default/public/tinymce/plugins/help/js/i18n/keynav/zh_TW.js +0 -93
- package/templates/default/public/tinymce/plugins/help/plugin.js +0 -826
- package/templates/default/public/tinymce/plugins/help/plugin.min.js +0 -1
- package/templates/default/public/tinymce/plugins/image/index.js +0 -7
- package/templates/default/public/tinymce/plugins/image/plugin.js +0 -1691
- package/templates/default/public/tinymce/plugins/image/plugin.min.js +0 -1
- package/templates/default/public/tinymce/plugins/importcss/index.js +0 -7
- package/templates/default/public/tinymce/plugins/importcss/plugin.js +0 -401
- package/templates/default/public/tinymce/plugins/importcss/plugin.min.js +0 -1
- package/templates/default/public/tinymce/plugins/insertdatetime/index.js +0 -7
- package/templates/default/public/tinymce/plugins/insertdatetime/plugin.js +0 -187
- package/templates/default/public/tinymce/plugins/insertdatetime/plugin.min.js +0 -1
- package/templates/default/public/tinymce/plugins/link/index.js +0 -7
- package/templates/default/public/tinymce/plugins/link/plugin.js +0 -1709
- package/templates/default/public/tinymce/plugins/link/plugin.min.js +0 -1
- package/templates/default/public/tinymce/plugins/lists/index.js +0 -7
- package/templates/default/public/tinymce/plugins/lists/plugin.js +0 -602
- package/templates/default/public/tinymce/plugins/lists/plugin.min.js +0 -1
- package/templates/default/public/tinymce/plugins/media/index.js +0 -7
- package/templates/default/public/tinymce/plugins/media/plugin.js +0 -1442
- package/templates/default/public/tinymce/plugins/media/plugin.min.js +0 -1
- package/templates/default/public/tinymce/plugins/nonbreaking/index.js +0 -7
- package/templates/default/public/tinymce/plugins/nonbreaking/plugin.js +0 -128
- package/templates/default/public/tinymce/plugins/nonbreaking/plugin.min.js +0 -1
- package/templates/default/public/tinymce/plugins/pagebreak/index.js +0 -7
- package/templates/default/public/tinymce/plugins/pagebreak/plugin.js +0 -123
- package/templates/default/public/tinymce/plugins/pagebreak/plugin.min.js +0 -1
- package/templates/default/public/tinymce/plugins/preview/index.js +0 -7
- package/templates/default/public/tinymce/plugins/preview/plugin.js +0 -843
- package/templates/default/public/tinymce/plugins/preview/plugin.min.js +0 -1
- package/templates/default/public/tinymce/plugins/quickbars/index.js +0 -7
- package/templates/default/public/tinymce/plugins/quickbars/plugin.js +0 -654
- package/templates/default/public/tinymce/plugins/quickbars/plugin.min.js +0 -1
- package/templates/default/public/tinymce/plugins/save/index.js +0 -7
- package/templates/default/public/tinymce/plugins/save/plugin.js +0 -136
- package/templates/default/public/tinymce/plugins/save/plugin.min.js +0 -1
- package/templates/default/public/tinymce/plugins/searchreplace/index.js +0 -7
- package/templates/default/public/tinymce/plugins/searchreplace/plugin.js +0 -1367
- package/templates/default/public/tinymce/plugins/searchreplace/plugin.min.js +0 -1
- package/templates/default/public/tinymce/plugins/table/index.js +0 -7
- package/templates/default/public/tinymce/plugins/table/plugin.js +0 -4008
- package/templates/default/public/tinymce/plugins/table/plugin.min.js +0 -1
- package/templates/default/public/tinymce/plugins/visualblocks/index.js +0 -7
- package/templates/default/public/tinymce/plugins/visualblocks/plugin.js +0 -106
- package/templates/default/public/tinymce/plugins/visualblocks/plugin.min.js +0 -1
- package/templates/default/public/tinymce/plugins/visualchars/index.js +0 -7
- package/templates/default/public/tinymce/plugins/visualchars/plugin.js +0 -808
- package/templates/default/public/tinymce/plugins/visualchars/plugin.min.js +0 -1
- package/templates/default/public/tinymce/plugins/wordcount/index.js +0 -7
- package/templates/default/public/tinymce/plugins/wordcount/plugin.js +0 -480
- package/templates/default/public/tinymce/plugins/wordcount/plugin.min.js +0 -1
- package/templates/default/public/tinymce/skins/content/dark/content.css +0 -75
- package/templates/default/public/tinymce/skins/content/dark/content.js +0 -10
- package/templates/default/public/tinymce/skins/content/dark/content.min.css +0 -10
- package/templates/default/public/tinymce/skins/content/dark/content.min.ts +0 -3
- package/templates/default/public/tinymce/skins/content/dark/content.ts +0 -3
- package/templates/default/public/tinymce/skins/content/default/content.css +0 -70
- package/templates/default/public/tinymce/skins/content/default/content.js +0 -10
- package/templates/default/public/tinymce/skins/content/default/content.min.css +0 -10
- package/templates/default/public/tinymce/skins/content/default/content.min.ts +0 -3
- package/templates/default/public/tinymce/skins/content/default/content.ts +0 -3
- package/templates/default/public/tinymce/skins/content/document/content.css +0 -75
- package/templates/default/public/tinymce/skins/content/document/content.js +0 -10
- package/templates/default/public/tinymce/skins/content/document/content.min.css +0 -10
- package/templates/default/public/tinymce/skins/content/document/content.min.ts +0 -3
- package/templates/default/public/tinymce/skins/content/document/content.ts +0 -3
- package/templates/default/public/tinymce/skins/content/tinymce-5/content.css +0 -70
- package/templates/default/public/tinymce/skins/content/tinymce-5/content.js +0 -10
- package/templates/default/public/tinymce/skins/content/tinymce-5/content.min.css +0 -10
- package/templates/default/public/tinymce/skins/content/tinymce-5/content.min.ts +0 -3
- package/templates/default/public/tinymce/skins/content/tinymce-5/content.ts +0 -3
- package/templates/default/public/tinymce/skins/content/tinymce-5-dark/content.css +0 -75
- package/templates/default/public/tinymce/skins/content/tinymce-5-dark/content.js +0 -10
- package/templates/default/public/tinymce/skins/content/tinymce-5-dark/content.min.css +0 -10
- package/templates/default/public/tinymce/skins/content/tinymce-5-dark/content.min.ts +0 -3
- package/templates/default/public/tinymce/skins/content/tinymce-5-dark/content.ts +0 -3
- package/templates/default/public/tinymce/skins/content/writer/content.css +0 -71
- package/templates/default/public/tinymce/skins/content/writer/content.js +0 -10
- package/templates/default/public/tinymce/skins/content/writer/content.min.css +0 -10
- package/templates/default/public/tinymce/skins/content/writer/content.min.ts +0 -3
- package/templates/default/public/tinymce/skins/content/writer/content.ts +0 -3
- package/templates/default/public/tinymce/skins/ui/oxide/content.css +0 -1037
- package/templates/default/public/tinymce/skins/ui/oxide/content.inline.css +0 -1031
- package/templates/default/public/tinymce/skins/ui/oxide/content.inline.js +0 -10
- package/templates/default/public/tinymce/skins/ui/oxide/content.inline.min.css +0 -10
- package/templates/default/public/tinymce/skins/ui/oxide/content.inline.min.ts +0 -116
- package/templates/default/public/tinymce/skins/ui/oxide/content.inline.ts +0 -116
- package/templates/default/public/tinymce/skins/ui/oxide/content.js +0 -10
- package/templates/default/public/tinymce/skins/ui/oxide/content.min.css +0 -10
- package/templates/default/public/tinymce/skins/ui/oxide/content.min.ts +0 -116
- package/templates/default/public/tinymce/skins/ui/oxide/content.ts +0 -116
- package/templates/default/public/tinymce/skins/ui/oxide/skin.css +0 -5615
- package/templates/default/public/tinymce/skins/ui/oxide/skin.js +0 -1
- package/templates/default/public/tinymce/skins/ui/oxide/skin.min.css +0 -1
- package/templates/default/public/tinymce/skins/ui/oxide/skin.min.ts +0 -507
- package/templates/default/public/tinymce/skins/ui/oxide/skin.shadowdom.css +0 -30
- package/templates/default/public/tinymce/skins/ui/oxide/skin.shadowdom.js +0 -1
- package/templates/default/public/tinymce/skins/ui/oxide/skin.shadowdom.min.css +0 -1
- package/templates/default/public/tinymce/skins/ui/oxide/skin.shadowdom.min.ts +0 -9
- package/templates/default/public/tinymce/skins/ui/oxide/skin.shadowdom.ts +0 -9
- package/templates/default/public/tinymce/skins/ui/oxide/skin.ts +0 -507
- package/templates/default/public/tinymce/skins/ui/oxide-dark/content.css +0 -1025
- package/templates/default/public/tinymce/skins/ui/oxide-dark/content.inline.css +0 -1031
- package/templates/default/public/tinymce/skins/ui/oxide-dark/content.inline.js +0 -10
- package/templates/default/public/tinymce/skins/ui/oxide-dark/content.inline.min.css +0 -10
- package/templates/default/public/tinymce/skins/ui/oxide-dark/content.inline.min.ts +0 -116
- package/templates/default/public/tinymce/skins/ui/oxide-dark/content.inline.ts +0 -116
- package/templates/default/public/tinymce/skins/ui/oxide-dark/content.js +0 -10
- package/templates/default/public/tinymce/skins/ui/oxide-dark/content.min.css +0 -10
- package/templates/default/public/tinymce/skins/ui/oxide-dark/content.min.ts +0 -116
- package/templates/default/public/tinymce/skins/ui/oxide-dark/content.ts +0 -116
- package/templates/default/public/tinymce/skins/ui/oxide-dark/skin.css +0 -5618
- package/templates/default/public/tinymce/skins/ui/oxide-dark/skin.js +0 -1
- package/templates/default/public/tinymce/skins/ui/oxide-dark/skin.min.css +0 -1
- package/templates/default/public/tinymce/skins/ui/oxide-dark/skin.min.ts +0 -507
- package/templates/default/public/tinymce/skins/ui/oxide-dark/skin.shadowdom.css +0 -30
- package/templates/default/public/tinymce/skins/ui/oxide-dark/skin.shadowdom.js +0 -1
- package/templates/default/public/tinymce/skins/ui/oxide-dark/skin.shadowdom.min.css +0 -1
- package/templates/default/public/tinymce/skins/ui/oxide-dark/skin.shadowdom.min.ts +0 -9
- package/templates/default/public/tinymce/skins/ui/oxide-dark/skin.shadowdom.ts +0 -9
- package/templates/default/public/tinymce/skins/ui/oxide-dark/skin.ts +0 -507
- package/templates/default/public/tinymce/skins/ui/tinymce-5/content.css +0 -1037
- package/templates/default/public/tinymce/skins/ui/tinymce-5/content.inline.css +0 -1031
- package/templates/default/public/tinymce/skins/ui/tinymce-5/content.inline.js +0 -10
- package/templates/default/public/tinymce/skins/ui/tinymce-5/content.inline.min.css +0 -10
- package/templates/default/public/tinymce/skins/ui/tinymce-5/content.inline.min.ts +0 -116
- package/templates/default/public/tinymce/skins/ui/tinymce-5/content.inline.ts +0 -116
- package/templates/default/public/tinymce/skins/ui/tinymce-5/content.js +0 -10
- package/templates/default/public/tinymce/skins/ui/tinymce-5/content.min.css +0 -10
- package/templates/default/public/tinymce/skins/ui/tinymce-5/content.min.ts +0 -116
- package/templates/default/public/tinymce/skins/ui/tinymce-5/content.ts +0 -116
- package/templates/default/public/tinymce/skins/ui/tinymce-5/skin.css +0 -5734
- package/templates/default/public/tinymce/skins/ui/tinymce-5/skin.js +0 -1
- package/templates/default/public/tinymce/skins/ui/tinymce-5/skin.min.css +0 -1
- package/templates/default/public/tinymce/skins/ui/tinymce-5/skin.min.ts +0 -508
- package/templates/default/public/tinymce/skins/ui/tinymce-5/skin.shadowdom.css +0 -30
- package/templates/default/public/tinymce/skins/ui/tinymce-5/skin.shadowdom.js +0 -1
- package/templates/default/public/tinymce/skins/ui/tinymce-5/skin.shadowdom.min.css +0 -1
- package/templates/default/public/tinymce/skins/ui/tinymce-5/skin.shadowdom.min.ts +0 -9
- package/templates/default/public/tinymce/skins/ui/tinymce-5/skin.shadowdom.ts +0 -9
- package/templates/default/public/tinymce/skins/ui/tinymce-5/skin.ts +0 -508
- package/templates/default/public/tinymce/skins/ui/tinymce-5-dark/content.css +0 -1025
- package/templates/default/public/tinymce/skins/ui/tinymce-5-dark/content.inline.css +0 -1031
- package/templates/default/public/tinymce/skins/ui/tinymce-5-dark/content.inline.js +0 -10
- package/templates/default/public/tinymce/skins/ui/tinymce-5-dark/content.inline.min.css +0 -10
- package/templates/default/public/tinymce/skins/ui/tinymce-5-dark/content.inline.min.ts +0 -116
- package/templates/default/public/tinymce/skins/ui/tinymce-5-dark/content.inline.ts +0 -116
- package/templates/default/public/tinymce/skins/ui/tinymce-5-dark/content.js +0 -10
- package/templates/default/public/tinymce/skins/ui/tinymce-5-dark/content.min.css +0 -10
- package/templates/default/public/tinymce/skins/ui/tinymce-5-dark/content.min.ts +0 -116
- package/templates/default/public/tinymce/skins/ui/tinymce-5-dark/content.ts +0 -116
- package/templates/default/public/tinymce/skins/ui/tinymce-5-dark/skin.css +0 -5734
- package/templates/default/public/tinymce/skins/ui/tinymce-5-dark/skin.js +0 -1
- package/templates/default/public/tinymce/skins/ui/tinymce-5-dark/skin.min.css +0 -1
- package/templates/default/public/tinymce/skins/ui/tinymce-5-dark/skin.min.ts +0 -508
- package/templates/default/public/tinymce/skins/ui/tinymce-5-dark/skin.shadowdom.css +0 -30
- package/templates/default/public/tinymce/skins/ui/tinymce-5-dark/skin.shadowdom.js +0 -1
- package/templates/default/public/tinymce/skins/ui/tinymce-5-dark/skin.shadowdom.min.css +0 -1
- package/templates/default/public/tinymce/skins/ui/tinymce-5-dark/skin.shadowdom.min.ts +0 -9
- package/templates/default/public/tinymce/skins/ui/tinymce-5-dark/skin.shadowdom.ts +0 -9
- package/templates/default/public/tinymce/skins/ui/tinymce-5-dark/skin.ts +0 -508
- package/templates/default/public/tinymce/themes/silver/index.js +0 -7
- package/templates/default/public/tinymce/themes/silver/theme.js +0 -34748
- package/templates/default/public/tinymce/themes/silver/theme.min.js +0 -1
- package/templates/default/public/tinymce/tinymce.d.ts +0 -3413
- package/templates/default/public/tinymce/tinymce.js +0 -41518
- package/templates/default/public/tinymce/tinymce.min.js +0 -10
|
@@ -1,1607 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* TinyMCE version 8.3.1 (2025-12-17)
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
(function () {
|
|
6
|
-
'use strict';
|
|
7
|
-
|
|
8
|
-
/* eslint-disable @typescript-eslint/no-wrapper-object-types */
|
|
9
|
-
const hasProto = (v, constructor, predicate) => {
|
|
10
|
-
if (predicate(v, constructor.prototype)) {
|
|
11
|
-
return true;
|
|
12
|
-
}
|
|
13
|
-
else {
|
|
14
|
-
// String-based fallback time
|
|
15
|
-
return v.constructor?.name === constructor.name;
|
|
16
|
-
}
|
|
17
|
-
};
|
|
18
|
-
const typeOf = (x) => {
|
|
19
|
-
const t = typeof x;
|
|
20
|
-
if (x === null) {
|
|
21
|
-
return 'null';
|
|
22
|
-
}
|
|
23
|
-
else if (t === 'object' && Array.isArray(x)) {
|
|
24
|
-
return 'array';
|
|
25
|
-
}
|
|
26
|
-
else if (t === 'object' && hasProto(x, String, (o, proto) => proto.isPrototypeOf(o))) {
|
|
27
|
-
return 'string';
|
|
28
|
-
}
|
|
29
|
-
else {
|
|
30
|
-
return t;
|
|
31
|
-
}
|
|
32
|
-
};
|
|
33
|
-
const isType$1 = (type) => (value) => typeOf(value) === type;
|
|
34
|
-
const isSimpleType = (type) => (value) => typeof value === type;
|
|
35
|
-
const eq$1 = (t) => (a) => t === a;
|
|
36
|
-
const isString = isType$1('string');
|
|
37
|
-
const isObject = isType$1('object');
|
|
38
|
-
const isArray = isType$1('array');
|
|
39
|
-
const isNull = eq$1(null);
|
|
40
|
-
const isBoolean = isSimpleType('boolean');
|
|
41
|
-
const isUndefined = eq$1(undefined);
|
|
42
|
-
const isNullable = (a) => a === null || a === undefined;
|
|
43
|
-
const isNonNullable = (a) => !isNullable(a);
|
|
44
|
-
const isFunction = isSimpleType('function');
|
|
45
|
-
const isNumber = isSimpleType('number');
|
|
46
|
-
|
|
47
|
-
const noop = () => { };
|
|
48
|
-
/** Compose a unary function with an n-ary function */
|
|
49
|
-
const compose = (fa, fb) => {
|
|
50
|
-
return (...args) => {
|
|
51
|
-
return fa(fb.apply(null, args));
|
|
52
|
-
};
|
|
53
|
-
};
|
|
54
|
-
/** Compose two unary functions. Similar to compose, but avoids using Function.prototype.apply. */
|
|
55
|
-
const compose1 = (fbc, fab) => (a) => fbc(fab(a));
|
|
56
|
-
const constant = (value) => {
|
|
57
|
-
return () => {
|
|
58
|
-
return value;
|
|
59
|
-
};
|
|
60
|
-
};
|
|
61
|
-
function curry(fn, ...initialArgs) {
|
|
62
|
-
return (...restArgs) => {
|
|
63
|
-
const all = initialArgs.concat(restArgs);
|
|
64
|
-
return fn.apply(null, all);
|
|
65
|
-
};
|
|
66
|
-
}
|
|
67
|
-
const never = constant(false);
|
|
68
|
-
const always = constant(true);
|
|
69
|
-
|
|
70
|
-
/**
|
|
71
|
-
* The `Optional` type represents a value (of any type) that potentially does
|
|
72
|
-
* not exist. Any `Optional<T>` can either be a `Some<T>` (in which case the
|
|
73
|
-
* value does exist) or a `None` (in which case the value does not exist). This
|
|
74
|
-
* module defines a whole lot of FP-inspired utility functions for dealing with
|
|
75
|
-
* `Optional` objects.
|
|
76
|
-
*
|
|
77
|
-
* Comparison with null or undefined:
|
|
78
|
-
* - We don't get fancy null coalescing operators with `Optional`
|
|
79
|
-
* - We do get fancy helper functions with `Optional`
|
|
80
|
-
* - `Optional` support nesting, and allow for the type to still be nullable (or
|
|
81
|
-
* another `Optional`)
|
|
82
|
-
* - There is no option to turn off strict-optional-checks like there is for
|
|
83
|
-
* strict-null-checks
|
|
84
|
-
*/
|
|
85
|
-
class Optional {
|
|
86
|
-
tag;
|
|
87
|
-
value;
|
|
88
|
-
// Sneaky optimisation: every instance of Optional.none is identical, so just
|
|
89
|
-
// reuse the same object
|
|
90
|
-
static singletonNone = new Optional(false);
|
|
91
|
-
// The internal representation has a `tag` and a `value`, but both are
|
|
92
|
-
// private: able to be console.logged, but not able to be accessed by code
|
|
93
|
-
constructor(tag, value) {
|
|
94
|
-
this.tag = tag;
|
|
95
|
-
this.value = value;
|
|
96
|
-
}
|
|
97
|
-
// --- Identities ---
|
|
98
|
-
/**
|
|
99
|
-
* Creates a new `Optional<T>` that **does** contain a value.
|
|
100
|
-
*/
|
|
101
|
-
static some(value) {
|
|
102
|
-
return new Optional(true, value);
|
|
103
|
-
}
|
|
104
|
-
/**
|
|
105
|
-
* Create a new `Optional<T>` that **does not** contain a value. `T` can be
|
|
106
|
-
* any type because we don't actually have a `T`.
|
|
107
|
-
*/
|
|
108
|
-
static none() {
|
|
109
|
-
return Optional.singletonNone;
|
|
110
|
-
}
|
|
111
|
-
/**
|
|
112
|
-
* Perform a transform on an `Optional` type. Regardless of whether this
|
|
113
|
-
* `Optional` contains a value or not, `fold` will return a value of type `U`.
|
|
114
|
-
* If this `Optional` does not contain a value, the `U` will be created by
|
|
115
|
-
* calling `onNone`. If this `Optional` does contain a value, the `U` will be
|
|
116
|
-
* created by calling `onSome`.
|
|
117
|
-
*
|
|
118
|
-
* For the FP enthusiasts in the room, this function:
|
|
119
|
-
* 1. Could be used to implement all of the functions below
|
|
120
|
-
* 2. Forms a catamorphism
|
|
121
|
-
*/
|
|
122
|
-
fold(onNone, onSome) {
|
|
123
|
-
if (this.tag) {
|
|
124
|
-
return onSome(this.value);
|
|
125
|
-
}
|
|
126
|
-
else {
|
|
127
|
-
return onNone();
|
|
128
|
-
}
|
|
129
|
-
}
|
|
130
|
-
/**
|
|
131
|
-
* Determine if this `Optional` object contains a value.
|
|
132
|
-
*/
|
|
133
|
-
isSome() {
|
|
134
|
-
return this.tag;
|
|
135
|
-
}
|
|
136
|
-
/**
|
|
137
|
-
* Determine if this `Optional` object **does not** contain a value.
|
|
138
|
-
*/
|
|
139
|
-
isNone() {
|
|
140
|
-
return !this.tag;
|
|
141
|
-
}
|
|
142
|
-
// --- Functor (name stolen from Haskell / maths) ---
|
|
143
|
-
/**
|
|
144
|
-
* Perform a transform on an `Optional` object, **if** there is a value. If
|
|
145
|
-
* you provide a function to turn a T into a U, this is the function you use
|
|
146
|
-
* to turn an `Optional<T>` into an `Optional<U>`. If this **does** contain
|
|
147
|
-
* a value then the output will also contain a value (that value being the
|
|
148
|
-
* output of `mapper(this.value)`), and if this **does not** contain a value
|
|
149
|
-
* then neither will the output.
|
|
150
|
-
*/
|
|
151
|
-
map(mapper) {
|
|
152
|
-
if (this.tag) {
|
|
153
|
-
return Optional.some(mapper(this.value));
|
|
154
|
-
}
|
|
155
|
-
else {
|
|
156
|
-
return Optional.none();
|
|
157
|
-
}
|
|
158
|
-
}
|
|
159
|
-
// --- Monad (name stolen from Haskell / maths) ---
|
|
160
|
-
/**
|
|
161
|
-
* Perform a transform on an `Optional` object, **if** there is a value.
|
|
162
|
-
* Unlike `map`, here the transform itself also returns an `Optional`.
|
|
163
|
-
*/
|
|
164
|
-
bind(binder) {
|
|
165
|
-
if (this.tag) {
|
|
166
|
-
return binder(this.value);
|
|
167
|
-
}
|
|
168
|
-
else {
|
|
169
|
-
return Optional.none();
|
|
170
|
-
}
|
|
171
|
-
}
|
|
172
|
-
// --- Traversable (name stolen from Haskell / maths) ---
|
|
173
|
-
/**
|
|
174
|
-
* For a given predicate, this function finds out if there **exists** a value
|
|
175
|
-
* inside this `Optional` object that meets the predicate. In practice, this
|
|
176
|
-
* means that for `Optional`s that do not contain a value it returns false (as
|
|
177
|
-
* no predicate-meeting value exists).
|
|
178
|
-
*/
|
|
179
|
-
exists(predicate) {
|
|
180
|
-
return this.tag && predicate(this.value);
|
|
181
|
-
}
|
|
182
|
-
/**
|
|
183
|
-
* For a given predicate, this function finds out if **all** the values inside
|
|
184
|
-
* this `Optional` object meet the predicate. In practice, this means that
|
|
185
|
-
* for `Optional`s that do not contain a value it returns true (as all 0
|
|
186
|
-
* objects do meet the predicate).
|
|
187
|
-
*/
|
|
188
|
-
forall(predicate) {
|
|
189
|
-
return !this.tag || predicate(this.value);
|
|
190
|
-
}
|
|
191
|
-
filter(predicate) {
|
|
192
|
-
if (!this.tag || predicate(this.value)) {
|
|
193
|
-
return this;
|
|
194
|
-
}
|
|
195
|
-
else {
|
|
196
|
-
return Optional.none();
|
|
197
|
-
}
|
|
198
|
-
}
|
|
199
|
-
// --- Getters ---
|
|
200
|
-
/**
|
|
201
|
-
* Get the value out of the inside of the `Optional` object, using a default
|
|
202
|
-
* `replacement` value if the provided `Optional` object does not contain a
|
|
203
|
-
* value.
|
|
204
|
-
*/
|
|
205
|
-
getOr(replacement) {
|
|
206
|
-
return this.tag ? this.value : replacement;
|
|
207
|
-
}
|
|
208
|
-
/**
|
|
209
|
-
* Get the value out of the inside of the `Optional` object, using a default
|
|
210
|
-
* `replacement` value if the provided `Optional` object does not contain a
|
|
211
|
-
* value. Unlike `getOr`, in this method the `replacement` object is also
|
|
212
|
-
* `Optional` - meaning that this method will always return an `Optional`.
|
|
213
|
-
*/
|
|
214
|
-
or(replacement) {
|
|
215
|
-
return this.tag ? this : replacement;
|
|
216
|
-
}
|
|
217
|
-
/**
|
|
218
|
-
* Get the value out of the inside of the `Optional` object, using a default
|
|
219
|
-
* `replacement` value if the provided `Optional` object does not contain a
|
|
220
|
-
* value. Unlike `getOr`, in this method the `replacement` value is
|
|
221
|
-
* "thunked" - that is to say that you don't pass a value to `getOrThunk`, you
|
|
222
|
-
* pass a function which (if called) will **return** the `value` you want to
|
|
223
|
-
* use.
|
|
224
|
-
*/
|
|
225
|
-
getOrThunk(thunk) {
|
|
226
|
-
return this.tag ? this.value : thunk();
|
|
227
|
-
}
|
|
228
|
-
/**
|
|
229
|
-
* Get the value out of the inside of the `Optional` object, using a default
|
|
230
|
-
* `replacement` value if the provided Optional object does not contain a
|
|
231
|
-
* value.
|
|
232
|
-
*
|
|
233
|
-
* Unlike `or`, in this method the `replacement` value is "thunked" - that is
|
|
234
|
-
* to say that you don't pass a value to `orThunk`, you pass a function which
|
|
235
|
-
* (if called) will **return** the `value` you want to use.
|
|
236
|
-
*
|
|
237
|
-
* Unlike `getOrThunk`, in this method the `replacement` value is also
|
|
238
|
-
* `Optional`, meaning that this method will always return an `Optional`.
|
|
239
|
-
*/
|
|
240
|
-
orThunk(thunk) {
|
|
241
|
-
return this.tag ? this : thunk();
|
|
242
|
-
}
|
|
243
|
-
/**
|
|
244
|
-
* Get the value out of the inside of the `Optional` object, throwing an
|
|
245
|
-
* exception if the provided `Optional` object does not contain a value.
|
|
246
|
-
*
|
|
247
|
-
* WARNING:
|
|
248
|
-
* You should only be using this function if you know that the `Optional`
|
|
249
|
-
* object **is not** empty (otherwise you're throwing exceptions in production
|
|
250
|
-
* code, which is bad).
|
|
251
|
-
*
|
|
252
|
-
* In tests this is more acceptable.
|
|
253
|
-
*
|
|
254
|
-
* Prefer other methods to this, such as `.each`.
|
|
255
|
-
*/
|
|
256
|
-
getOrDie(message) {
|
|
257
|
-
if (!this.tag) {
|
|
258
|
-
throw new Error(message ?? 'Called getOrDie on None');
|
|
259
|
-
}
|
|
260
|
-
else {
|
|
261
|
-
return this.value;
|
|
262
|
-
}
|
|
263
|
-
}
|
|
264
|
-
// --- Interop with null and undefined ---
|
|
265
|
-
/**
|
|
266
|
-
* Creates an `Optional` value from a nullable (or undefined-able) input.
|
|
267
|
-
* Null, or undefined, is converted to `None`, and anything else is converted
|
|
268
|
-
* to `Some`.
|
|
269
|
-
*/
|
|
270
|
-
static from(value) {
|
|
271
|
-
return isNonNullable(value) ? Optional.some(value) : Optional.none();
|
|
272
|
-
}
|
|
273
|
-
/**
|
|
274
|
-
* Converts an `Optional` to a nullable type, by getting the value if it
|
|
275
|
-
* exists, or returning `null` if it does not.
|
|
276
|
-
*/
|
|
277
|
-
getOrNull() {
|
|
278
|
-
return this.tag ? this.value : null;
|
|
279
|
-
}
|
|
280
|
-
/**
|
|
281
|
-
* Converts an `Optional` to an undefined-able type, by getting the value if
|
|
282
|
-
* it exists, or returning `undefined` if it does not.
|
|
283
|
-
*/
|
|
284
|
-
getOrUndefined() {
|
|
285
|
-
return this.value;
|
|
286
|
-
}
|
|
287
|
-
// --- Utilities ---
|
|
288
|
-
/**
|
|
289
|
-
* If the `Optional` contains a value, perform an action on that value.
|
|
290
|
-
* Unlike the rest of the methods on this type, `.each` has side-effects. If
|
|
291
|
-
* you want to transform an `Optional<T>` **into** something, then this is not
|
|
292
|
-
* the method for you. If you want to use an `Optional<T>` to **do**
|
|
293
|
-
* something, then this is the method for you - provided you're okay with not
|
|
294
|
-
* doing anything in the case where the `Optional` doesn't have a value inside
|
|
295
|
-
* it. If you're not sure whether your use-case fits into transforming
|
|
296
|
-
* **into** something or **doing** something, check whether it has a return
|
|
297
|
-
* value. If it does, you should be performing a transform.
|
|
298
|
-
*/
|
|
299
|
-
each(worker) {
|
|
300
|
-
if (this.tag) {
|
|
301
|
-
worker(this.value);
|
|
302
|
-
}
|
|
303
|
-
}
|
|
304
|
-
/**
|
|
305
|
-
* Turn the `Optional` object into an array that contains all of the values
|
|
306
|
-
* stored inside the `Optional`. In practice, this means the output will have
|
|
307
|
-
* either 0 or 1 elements.
|
|
308
|
-
*/
|
|
309
|
-
toArray() {
|
|
310
|
-
return this.tag ? [this.value] : [];
|
|
311
|
-
}
|
|
312
|
-
/**
|
|
313
|
-
* Turn the `Optional` object into a string for debugging or printing. Not
|
|
314
|
-
* recommended for production code, but good for debugging. Also note that
|
|
315
|
-
* these days an `Optional` object can be logged to the console directly, and
|
|
316
|
-
* its inner value (if it exists) will be visible.
|
|
317
|
-
*/
|
|
318
|
-
toString() {
|
|
319
|
-
return this.tag ? `some(${this.value})` : 'none()';
|
|
320
|
-
}
|
|
321
|
-
}
|
|
322
|
-
|
|
323
|
-
const nativePush = Array.prototype.push;
|
|
324
|
-
const map = (xs, f) => {
|
|
325
|
-
// pre-allocating array size when it's guaranteed to be known
|
|
326
|
-
// http://jsperf.com/push-allocated-vs-dynamic/22
|
|
327
|
-
const len = xs.length;
|
|
328
|
-
const r = new Array(len);
|
|
329
|
-
for (let i = 0; i < len; i++) {
|
|
330
|
-
const x = xs[i];
|
|
331
|
-
r[i] = f(x, i);
|
|
332
|
-
}
|
|
333
|
-
return r;
|
|
334
|
-
};
|
|
335
|
-
// Unwound implementing other functions in terms of each.
|
|
336
|
-
// The code size is roughly the same, and it should allow for better optimisation.
|
|
337
|
-
// const each = function<T, U>(xs: T[], f: (x: T, i?: number, xs?: T[]) => void): void {
|
|
338
|
-
const each$1 = (xs, f) => {
|
|
339
|
-
for (let i = 0, len = xs.length; i < len; i++) {
|
|
340
|
-
const x = xs[i];
|
|
341
|
-
f(x, i);
|
|
342
|
-
}
|
|
343
|
-
};
|
|
344
|
-
const filter$1 = (xs, pred) => {
|
|
345
|
-
const r = [];
|
|
346
|
-
for (let i = 0, len = xs.length; i < len; i++) {
|
|
347
|
-
const x = xs[i];
|
|
348
|
-
if (pred(x, i)) {
|
|
349
|
-
r.push(x);
|
|
350
|
-
}
|
|
351
|
-
}
|
|
352
|
-
return r;
|
|
353
|
-
};
|
|
354
|
-
const findUntil = (xs, pred, until) => {
|
|
355
|
-
for (let i = 0, len = xs.length; i < len; i++) {
|
|
356
|
-
const x = xs[i];
|
|
357
|
-
if (pred(x, i)) {
|
|
358
|
-
return Optional.some(x);
|
|
359
|
-
}
|
|
360
|
-
else if (until(x, i)) {
|
|
361
|
-
break;
|
|
362
|
-
}
|
|
363
|
-
}
|
|
364
|
-
return Optional.none();
|
|
365
|
-
};
|
|
366
|
-
const find$1 = (xs, pred) => {
|
|
367
|
-
return findUntil(xs, pred, never);
|
|
368
|
-
};
|
|
369
|
-
const flatten = (xs) => {
|
|
370
|
-
// Note, this is possible because push supports multiple arguments:
|
|
371
|
-
// http://jsperf.com/concat-push/6
|
|
372
|
-
// Note that in the past, concat() would silently work (very slowly) for array-like objects.
|
|
373
|
-
// With this change it will throw an error.
|
|
374
|
-
const r = [];
|
|
375
|
-
for (let i = 0, len = xs.length; i < len; ++i) {
|
|
376
|
-
// Ensure that each value is an array itself
|
|
377
|
-
if (!isArray(xs[i])) {
|
|
378
|
-
throw new Error('Arr.flatten item ' + i + ' was not an array, input: ' + xs);
|
|
379
|
-
}
|
|
380
|
-
nativePush.apply(r, xs[i]);
|
|
381
|
-
}
|
|
382
|
-
return r;
|
|
383
|
-
};
|
|
384
|
-
const bind$3 = (xs, f) => flatten(map(xs, f));
|
|
385
|
-
const get$5 = (xs, i) => i >= 0 && i < xs.length ? Optional.some(xs[i]) : Optional.none();
|
|
386
|
-
const head = (xs) => get$5(xs, 0);
|
|
387
|
-
const findMap = (arr, f) => {
|
|
388
|
-
for (let i = 0; i < arr.length; i++) {
|
|
389
|
-
const r = f(arr[i], i);
|
|
390
|
-
if (r.isSome()) {
|
|
391
|
-
return r;
|
|
392
|
-
}
|
|
393
|
-
}
|
|
394
|
-
return Optional.none();
|
|
395
|
-
};
|
|
396
|
-
|
|
397
|
-
// There are many variations of Object iteration that are faster than the 'for-in' style:
|
|
398
|
-
// http://jsperf.com/object-keys-iteration/107
|
|
399
|
-
//
|
|
400
|
-
// Use the native keys if it is available (IE9+), otherwise fall back to manually filtering
|
|
401
|
-
const keys = Object.keys;
|
|
402
|
-
const each = (obj, f) => {
|
|
403
|
-
const props = keys(obj);
|
|
404
|
-
for (let k = 0, len = props.length; k < len; k++) {
|
|
405
|
-
const i = props[k];
|
|
406
|
-
const x = obj[i];
|
|
407
|
-
f(x, i);
|
|
408
|
-
}
|
|
409
|
-
};
|
|
410
|
-
|
|
411
|
-
const Cell = (initial) => {
|
|
412
|
-
let value = initial;
|
|
413
|
-
const get = () => {
|
|
414
|
-
return value;
|
|
415
|
-
};
|
|
416
|
-
const set = (v) => {
|
|
417
|
-
value = v;
|
|
418
|
-
};
|
|
419
|
-
return {
|
|
420
|
-
get,
|
|
421
|
-
set
|
|
422
|
-
};
|
|
423
|
-
};
|
|
424
|
-
|
|
425
|
-
// Use window object as the global if it's available since CSP will block script evals
|
|
426
|
-
// eslint-disable-next-line @typescript-eslint/no-implied-eval
|
|
427
|
-
const Global = typeof window !== 'undefined' ? window : Function('return this;')();
|
|
428
|
-
|
|
429
|
-
/*
|
|
430
|
-
Notes on the lift functions:
|
|
431
|
-
- We used to have a generic liftN, but we were concerned about its type-safety, and the below variants were faster in microbenchmarks.
|
|
432
|
-
- The getOrDie calls are partial functions, but are checked beforehand. This is faster and more convenient (but less safe) than folds.
|
|
433
|
-
- && is used instead of a loop for simplicity and performance.
|
|
434
|
-
*/
|
|
435
|
-
const lift2 = (oa, ob, f) => oa.isSome() && ob.isSome() ? Optional.some(f(oa.getOrDie(), ob.getOrDie())) : Optional.none();
|
|
436
|
-
|
|
437
|
-
/** path :: ([String], JsObj?) -> JsObj */
|
|
438
|
-
const path = (parts, scope) => {
|
|
439
|
-
let o = scope !== undefined && scope !== null ? scope : Global;
|
|
440
|
-
for (let i = 0; i < parts.length && o !== undefined && o !== null; ++i) {
|
|
441
|
-
o = o[parts[i]];
|
|
442
|
-
}
|
|
443
|
-
return o;
|
|
444
|
-
};
|
|
445
|
-
/** resolve :: (String, JsObj?) -> JsObj */
|
|
446
|
-
const resolve = (p, scope) => {
|
|
447
|
-
const parts = p.split('.');
|
|
448
|
-
return path(parts, scope);
|
|
449
|
-
};
|
|
450
|
-
|
|
451
|
-
const singleton = (doRevoke) => {
|
|
452
|
-
const subject = Cell(Optional.none());
|
|
453
|
-
const revoke = () => subject.get().each(doRevoke);
|
|
454
|
-
const clear = () => {
|
|
455
|
-
revoke();
|
|
456
|
-
subject.set(Optional.none());
|
|
457
|
-
};
|
|
458
|
-
const isSet = () => subject.get().isSome();
|
|
459
|
-
const get = () => subject.get();
|
|
460
|
-
const set = (s) => {
|
|
461
|
-
revoke();
|
|
462
|
-
subject.set(Optional.some(s));
|
|
463
|
-
};
|
|
464
|
-
return {
|
|
465
|
-
clear,
|
|
466
|
-
isSet,
|
|
467
|
-
get,
|
|
468
|
-
set
|
|
469
|
-
};
|
|
470
|
-
};
|
|
471
|
-
const unbindable = () => singleton((s) => s.unbind());
|
|
472
|
-
const value = () => {
|
|
473
|
-
const subject = singleton(noop);
|
|
474
|
-
const on = (f) => subject.get().each(f);
|
|
475
|
-
return {
|
|
476
|
-
...subject,
|
|
477
|
-
on
|
|
478
|
-
};
|
|
479
|
-
};
|
|
480
|
-
|
|
481
|
-
const contains = (str, substr, start = 0, end) => {
|
|
482
|
-
const idx = str.indexOf(substr, start);
|
|
483
|
-
if (idx !== -1) {
|
|
484
|
-
return isUndefined(end) ? true : idx + substr.length <= end;
|
|
485
|
-
}
|
|
486
|
-
else {
|
|
487
|
-
return false;
|
|
488
|
-
}
|
|
489
|
-
};
|
|
490
|
-
|
|
491
|
-
// Run a function fn after rate ms. If another invocation occurs
|
|
492
|
-
// during the time it is waiting, ignore it completely.
|
|
493
|
-
const first = (fn, rate) => {
|
|
494
|
-
let timer = null;
|
|
495
|
-
const cancel = () => {
|
|
496
|
-
if (!isNull(timer)) {
|
|
497
|
-
clearTimeout(timer);
|
|
498
|
-
timer = null;
|
|
499
|
-
}
|
|
500
|
-
};
|
|
501
|
-
const throttle = (...args) => {
|
|
502
|
-
if (isNull(timer)) {
|
|
503
|
-
timer = setTimeout(() => {
|
|
504
|
-
timer = null;
|
|
505
|
-
fn.apply(null, args);
|
|
506
|
-
}, rate);
|
|
507
|
-
}
|
|
508
|
-
};
|
|
509
|
-
return {
|
|
510
|
-
cancel,
|
|
511
|
-
throttle
|
|
512
|
-
};
|
|
513
|
-
};
|
|
514
|
-
|
|
515
|
-
const cached = (f) => {
|
|
516
|
-
let called = false;
|
|
517
|
-
let r;
|
|
518
|
-
return (...args) => {
|
|
519
|
-
if (!called) {
|
|
520
|
-
called = true;
|
|
521
|
-
r = f.apply(null, args);
|
|
522
|
-
}
|
|
523
|
-
return r;
|
|
524
|
-
};
|
|
525
|
-
};
|
|
526
|
-
|
|
527
|
-
var global$3 = tinymce.util.Tools.resolve('tinymce.PluginManager');
|
|
528
|
-
|
|
529
|
-
const get$4 = (fullscreenState) => ({
|
|
530
|
-
isFullscreen: () => fullscreenState.get() !== null
|
|
531
|
-
});
|
|
532
|
-
|
|
533
|
-
const fromHtml = (html, scope) => {
|
|
534
|
-
const doc = scope || document;
|
|
535
|
-
const div = doc.createElement('div');
|
|
536
|
-
div.innerHTML = html;
|
|
537
|
-
if (!div.hasChildNodes() || div.childNodes.length > 1) {
|
|
538
|
-
const message = 'HTML does not have a single root node';
|
|
539
|
-
// eslint-disable-next-line no-console
|
|
540
|
-
console.error(message, html);
|
|
541
|
-
throw new Error(message);
|
|
542
|
-
}
|
|
543
|
-
return fromDom(div.childNodes[0]);
|
|
544
|
-
};
|
|
545
|
-
const fromTag = (tag, scope) => {
|
|
546
|
-
const doc = scope || document;
|
|
547
|
-
const node = doc.createElement(tag);
|
|
548
|
-
return fromDom(node);
|
|
549
|
-
};
|
|
550
|
-
const fromText = (text, scope) => {
|
|
551
|
-
const doc = scope || document;
|
|
552
|
-
const node = doc.createTextNode(text);
|
|
553
|
-
return fromDom(node);
|
|
554
|
-
};
|
|
555
|
-
const fromDom = (node) => {
|
|
556
|
-
// TODO: Consider removing this check, but left atm for safety
|
|
557
|
-
if (node === null || node === undefined) {
|
|
558
|
-
throw new Error('Node cannot be null or undefined');
|
|
559
|
-
}
|
|
560
|
-
return {
|
|
561
|
-
dom: node
|
|
562
|
-
};
|
|
563
|
-
};
|
|
564
|
-
const fromPoint = (docElm, x, y) => Optional.from(docElm.dom.elementFromPoint(x, y)).map(fromDom);
|
|
565
|
-
// tslint:disable-next-line:variable-name
|
|
566
|
-
const SugarElement = {
|
|
567
|
-
fromHtml,
|
|
568
|
-
fromTag,
|
|
569
|
-
fromText,
|
|
570
|
-
fromDom,
|
|
571
|
-
fromPoint
|
|
572
|
-
};
|
|
573
|
-
|
|
574
|
-
const DOCUMENT = 9;
|
|
575
|
-
const DOCUMENT_FRAGMENT = 11;
|
|
576
|
-
const ELEMENT = 1;
|
|
577
|
-
const TEXT = 3;
|
|
578
|
-
|
|
579
|
-
const is = (element, selector) => {
|
|
580
|
-
const dom = element.dom;
|
|
581
|
-
if (dom.nodeType !== ELEMENT) {
|
|
582
|
-
return false;
|
|
583
|
-
}
|
|
584
|
-
else {
|
|
585
|
-
const elem = dom;
|
|
586
|
-
if (elem.matches !== undefined) {
|
|
587
|
-
return elem.matches(selector);
|
|
588
|
-
}
|
|
589
|
-
else if (elem.msMatchesSelector !== undefined) {
|
|
590
|
-
return elem.msMatchesSelector(selector);
|
|
591
|
-
}
|
|
592
|
-
else if (elem.webkitMatchesSelector !== undefined) {
|
|
593
|
-
return elem.webkitMatchesSelector(selector);
|
|
594
|
-
}
|
|
595
|
-
else if (elem.mozMatchesSelector !== undefined) {
|
|
596
|
-
// cast to any as mozMatchesSelector doesn't exist in TS DOM lib
|
|
597
|
-
return elem.mozMatchesSelector(selector);
|
|
598
|
-
}
|
|
599
|
-
else {
|
|
600
|
-
throw new Error('Browser lacks native selectors');
|
|
601
|
-
} // unfortunately we can't throw this on startup :(
|
|
602
|
-
}
|
|
603
|
-
};
|
|
604
|
-
const bypassSelector = (dom) =>
|
|
605
|
-
// Only elements, documents and shadow roots support querySelector
|
|
606
|
-
// shadow root element type is DOCUMENT_FRAGMENT
|
|
607
|
-
dom.nodeType !== ELEMENT && dom.nodeType !== DOCUMENT && dom.nodeType !== DOCUMENT_FRAGMENT ||
|
|
608
|
-
// IE fix for complex queries on empty nodes: http://jsfiddle.net/spyder/fv9ptr5L/
|
|
609
|
-
dom.childElementCount === 0;
|
|
610
|
-
const all$1 = (selector, scope) => {
|
|
611
|
-
const base = scope === undefined ? document : scope.dom;
|
|
612
|
-
return bypassSelector(base) ? [] : map(base.querySelectorAll(selector), SugarElement.fromDom);
|
|
613
|
-
};
|
|
614
|
-
|
|
615
|
-
const eq = (e1, e2) => e1.dom === e2.dom;
|
|
616
|
-
|
|
617
|
-
const DeviceType = (os, browser, userAgent, mediaMatch) => {
|
|
618
|
-
const isiPad = os.isiOS() && /ipad/i.test(userAgent) === true;
|
|
619
|
-
const isiPhone = os.isiOS() && !isiPad;
|
|
620
|
-
const isMobile = os.isiOS() || os.isAndroid();
|
|
621
|
-
const isTouch = isMobile || mediaMatch('(pointer:coarse)');
|
|
622
|
-
const isTablet = isiPad || !isiPhone && isMobile && mediaMatch('(min-device-width:768px)');
|
|
623
|
-
const isPhone = isiPhone || isMobile && !isTablet;
|
|
624
|
-
const iOSwebview = browser.isSafari() && os.isiOS() && /safari/i.test(userAgent) === false;
|
|
625
|
-
const isDesktop = !isPhone && !isTablet && !iOSwebview;
|
|
626
|
-
return {
|
|
627
|
-
isiPad: constant(isiPad),
|
|
628
|
-
isiPhone: constant(isiPhone),
|
|
629
|
-
isTablet: constant(isTablet),
|
|
630
|
-
isPhone: constant(isPhone),
|
|
631
|
-
isTouch: constant(isTouch),
|
|
632
|
-
isAndroid: os.isAndroid,
|
|
633
|
-
isiOS: os.isiOS,
|
|
634
|
-
isWebView: constant(iOSwebview),
|
|
635
|
-
isDesktop: constant(isDesktop)
|
|
636
|
-
};
|
|
637
|
-
};
|
|
638
|
-
|
|
639
|
-
const firstMatch = (regexes, s) => {
|
|
640
|
-
for (let i = 0; i < regexes.length; i++) {
|
|
641
|
-
const x = regexes[i];
|
|
642
|
-
if (x.test(s)) {
|
|
643
|
-
return x;
|
|
644
|
-
}
|
|
645
|
-
}
|
|
646
|
-
return undefined;
|
|
647
|
-
};
|
|
648
|
-
const find = (regexes, agent) => {
|
|
649
|
-
const r = firstMatch(regexes, agent);
|
|
650
|
-
if (!r) {
|
|
651
|
-
return { major: 0, minor: 0 };
|
|
652
|
-
}
|
|
653
|
-
const group = (i) => {
|
|
654
|
-
return Number(agent.replace(r, '$' + i));
|
|
655
|
-
};
|
|
656
|
-
return nu$2(group(1), group(2));
|
|
657
|
-
};
|
|
658
|
-
const detect$3 = (versionRegexes, agent) => {
|
|
659
|
-
const cleanedAgent = String(agent).toLowerCase();
|
|
660
|
-
if (versionRegexes.length === 0) {
|
|
661
|
-
return unknown$2();
|
|
662
|
-
}
|
|
663
|
-
return find(versionRegexes, cleanedAgent);
|
|
664
|
-
};
|
|
665
|
-
const unknown$2 = () => {
|
|
666
|
-
return nu$2(0, 0);
|
|
667
|
-
};
|
|
668
|
-
const nu$2 = (major, minor) => {
|
|
669
|
-
return { major, minor };
|
|
670
|
-
};
|
|
671
|
-
const Version = {
|
|
672
|
-
nu: nu$2,
|
|
673
|
-
detect: detect$3,
|
|
674
|
-
unknown: unknown$2
|
|
675
|
-
};
|
|
676
|
-
|
|
677
|
-
const detectBrowser$1 = (browsers, userAgentData) => {
|
|
678
|
-
return findMap(userAgentData.brands, (uaBrand) => {
|
|
679
|
-
const lcBrand = uaBrand.brand.toLowerCase();
|
|
680
|
-
return find$1(browsers, (browser) => lcBrand === browser.brand?.toLowerCase())
|
|
681
|
-
.map((info) => ({
|
|
682
|
-
current: info.name,
|
|
683
|
-
version: Version.nu(parseInt(uaBrand.version, 10), 0)
|
|
684
|
-
}));
|
|
685
|
-
});
|
|
686
|
-
};
|
|
687
|
-
|
|
688
|
-
const detect$2 = (candidates, userAgent) => {
|
|
689
|
-
const agent = String(userAgent).toLowerCase();
|
|
690
|
-
return find$1(candidates, (candidate) => {
|
|
691
|
-
return candidate.search(agent);
|
|
692
|
-
});
|
|
693
|
-
};
|
|
694
|
-
// They (browser and os) are the same at the moment, but they might
|
|
695
|
-
// not stay that way.
|
|
696
|
-
const detectBrowser = (browsers, userAgent) => {
|
|
697
|
-
return detect$2(browsers, userAgent).map((browser) => {
|
|
698
|
-
const version = Version.detect(browser.versionRegexes, userAgent);
|
|
699
|
-
return {
|
|
700
|
-
current: browser.name,
|
|
701
|
-
version
|
|
702
|
-
};
|
|
703
|
-
});
|
|
704
|
-
};
|
|
705
|
-
const detectOs = (oses, userAgent) => {
|
|
706
|
-
return detect$2(oses, userAgent).map((os) => {
|
|
707
|
-
const version = Version.detect(os.versionRegexes, userAgent);
|
|
708
|
-
return {
|
|
709
|
-
current: os.name,
|
|
710
|
-
version
|
|
711
|
-
};
|
|
712
|
-
});
|
|
713
|
-
};
|
|
714
|
-
|
|
715
|
-
const normalVersionRegex = /.*?version\/\ ?([0-9]+)\.([0-9]+).*/;
|
|
716
|
-
const checkContains = (target) => {
|
|
717
|
-
return (uastring) => {
|
|
718
|
-
return contains(uastring, target);
|
|
719
|
-
};
|
|
720
|
-
};
|
|
721
|
-
const browsers = [
|
|
722
|
-
// This is legacy Edge
|
|
723
|
-
{
|
|
724
|
-
name: 'Edge',
|
|
725
|
-
versionRegexes: [/.*?edge\/ ?([0-9]+)\.([0-9]+)$/],
|
|
726
|
-
search: (uastring) => {
|
|
727
|
-
return contains(uastring, 'edge/') && contains(uastring, 'chrome') && contains(uastring, 'safari') && contains(uastring, 'applewebkit');
|
|
728
|
-
}
|
|
729
|
-
},
|
|
730
|
-
// This is Google Chrome and Chromium Edge
|
|
731
|
-
{
|
|
732
|
-
name: 'Chromium',
|
|
733
|
-
brand: 'Chromium',
|
|
734
|
-
versionRegexes: [/.*?chrome\/([0-9]+)\.([0-9]+).*/, normalVersionRegex],
|
|
735
|
-
search: (uastring) => {
|
|
736
|
-
return contains(uastring, 'chrome') && !contains(uastring, 'chromeframe');
|
|
737
|
-
}
|
|
738
|
-
},
|
|
739
|
-
{
|
|
740
|
-
name: 'IE',
|
|
741
|
-
versionRegexes: [/.*?msie\ ?([0-9]+)\.([0-9]+).*/, /.*?rv:([0-9]+)\.([0-9]+).*/],
|
|
742
|
-
search: (uastring) => {
|
|
743
|
-
return contains(uastring, 'msie') || contains(uastring, 'trident');
|
|
744
|
-
}
|
|
745
|
-
},
|
|
746
|
-
// INVESTIGATE: Is this still the Opera user agent?
|
|
747
|
-
{
|
|
748
|
-
name: 'Opera',
|
|
749
|
-
versionRegexes: [normalVersionRegex, /.*?opera\/([0-9]+)\.([0-9]+).*/],
|
|
750
|
-
search: checkContains('opera')
|
|
751
|
-
},
|
|
752
|
-
{
|
|
753
|
-
name: 'Firefox',
|
|
754
|
-
versionRegexes: [/.*?firefox\/\ ?([0-9]+)\.([0-9]+).*/],
|
|
755
|
-
search: checkContains('firefox')
|
|
756
|
-
},
|
|
757
|
-
{
|
|
758
|
-
name: 'Safari',
|
|
759
|
-
versionRegexes: [normalVersionRegex, /.*?cpu os ([0-9]+)_([0-9]+).*/],
|
|
760
|
-
search: (uastring) => {
|
|
761
|
-
return (contains(uastring, 'safari') || contains(uastring, 'mobile/')) && contains(uastring, 'applewebkit');
|
|
762
|
-
}
|
|
763
|
-
}
|
|
764
|
-
];
|
|
765
|
-
const oses = [
|
|
766
|
-
{
|
|
767
|
-
name: 'Windows',
|
|
768
|
-
search: checkContains('win'),
|
|
769
|
-
versionRegexes: [/.*?windows\ nt\ ?([0-9]+)\.([0-9]+).*/]
|
|
770
|
-
},
|
|
771
|
-
{
|
|
772
|
-
name: 'iOS',
|
|
773
|
-
search: (uastring) => {
|
|
774
|
-
return contains(uastring, 'iphone') || contains(uastring, 'ipad');
|
|
775
|
-
},
|
|
776
|
-
versionRegexes: [/.*?version\/\ ?([0-9]+)\.([0-9]+).*/, /.*cpu os ([0-9]+)_([0-9]+).*/, /.*cpu iphone os ([0-9]+)_([0-9]+).*/]
|
|
777
|
-
},
|
|
778
|
-
{
|
|
779
|
-
name: 'Android',
|
|
780
|
-
search: checkContains('android'),
|
|
781
|
-
versionRegexes: [/.*?android\ ?([0-9]+)\.([0-9]+).*/]
|
|
782
|
-
},
|
|
783
|
-
{
|
|
784
|
-
name: 'macOS',
|
|
785
|
-
search: checkContains('mac os x'),
|
|
786
|
-
versionRegexes: [/.*?mac\ os\ x\ ?([0-9]+)_([0-9]+).*/]
|
|
787
|
-
},
|
|
788
|
-
{
|
|
789
|
-
name: 'Linux',
|
|
790
|
-
search: checkContains('linux'),
|
|
791
|
-
versionRegexes: []
|
|
792
|
-
},
|
|
793
|
-
{ name: 'Solaris',
|
|
794
|
-
search: checkContains('sunos'),
|
|
795
|
-
versionRegexes: []
|
|
796
|
-
},
|
|
797
|
-
{
|
|
798
|
-
name: 'FreeBSD',
|
|
799
|
-
search: checkContains('freebsd'),
|
|
800
|
-
versionRegexes: []
|
|
801
|
-
},
|
|
802
|
-
{
|
|
803
|
-
name: 'ChromeOS',
|
|
804
|
-
search: checkContains('cros'),
|
|
805
|
-
versionRegexes: [/.*?chrome\/([0-9]+)\.([0-9]+).*/]
|
|
806
|
-
}
|
|
807
|
-
];
|
|
808
|
-
const PlatformInfo = {
|
|
809
|
-
browsers: constant(browsers),
|
|
810
|
-
oses: constant(oses)
|
|
811
|
-
};
|
|
812
|
-
|
|
813
|
-
const edge = 'Edge';
|
|
814
|
-
const chromium = 'Chromium';
|
|
815
|
-
const ie = 'IE';
|
|
816
|
-
const opera = 'Opera';
|
|
817
|
-
const firefox = 'Firefox';
|
|
818
|
-
const safari = 'Safari';
|
|
819
|
-
const unknown$1 = () => {
|
|
820
|
-
return nu$1({
|
|
821
|
-
current: undefined,
|
|
822
|
-
version: Version.unknown()
|
|
823
|
-
});
|
|
824
|
-
};
|
|
825
|
-
const nu$1 = (info) => {
|
|
826
|
-
const current = info.current;
|
|
827
|
-
const version = info.version;
|
|
828
|
-
const isBrowser = (name) => () => current === name;
|
|
829
|
-
return {
|
|
830
|
-
current,
|
|
831
|
-
version,
|
|
832
|
-
isEdge: isBrowser(edge),
|
|
833
|
-
isChromium: isBrowser(chromium),
|
|
834
|
-
// NOTE: isIe just looks too weird
|
|
835
|
-
isIE: isBrowser(ie),
|
|
836
|
-
isOpera: isBrowser(opera),
|
|
837
|
-
isFirefox: isBrowser(firefox),
|
|
838
|
-
isSafari: isBrowser(safari)
|
|
839
|
-
};
|
|
840
|
-
};
|
|
841
|
-
const Browser = {
|
|
842
|
-
unknown: unknown$1,
|
|
843
|
-
nu: nu$1,
|
|
844
|
-
edge: constant(edge),
|
|
845
|
-
chromium: constant(chromium),
|
|
846
|
-
ie: constant(ie),
|
|
847
|
-
opera: constant(opera),
|
|
848
|
-
firefox: constant(firefox),
|
|
849
|
-
safari: constant(safari)
|
|
850
|
-
};
|
|
851
|
-
|
|
852
|
-
const windows = 'Windows';
|
|
853
|
-
const ios = 'iOS';
|
|
854
|
-
const android = 'Android';
|
|
855
|
-
const linux = 'Linux';
|
|
856
|
-
const macos = 'macOS';
|
|
857
|
-
const solaris = 'Solaris';
|
|
858
|
-
const freebsd = 'FreeBSD';
|
|
859
|
-
const chromeos = 'ChromeOS';
|
|
860
|
-
// Though there is a bit of dupe with this and Browser, trying to
|
|
861
|
-
// reuse code makes it much harder to follow and change.
|
|
862
|
-
const unknown = () => {
|
|
863
|
-
return nu({
|
|
864
|
-
current: undefined,
|
|
865
|
-
version: Version.unknown()
|
|
866
|
-
});
|
|
867
|
-
};
|
|
868
|
-
const nu = (info) => {
|
|
869
|
-
const current = info.current;
|
|
870
|
-
const version = info.version;
|
|
871
|
-
const isOS = (name) => () => current === name;
|
|
872
|
-
return {
|
|
873
|
-
current,
|
|
874
|
-
version,
|
|
875
|
-
isWindows: isOS(windows),
|
|
876
|
-
// TODO: Fix capitalisation
|
|
877
|
-
isiOS: isOS(ios),
|
|
878
|
-
isAndroid: isOS(android),
|
|
879
|
-
isMacOS: isOS(macos),
|
|
880
|
-
isLinux: isOS(linux),
|
|
881
|
-
isSolaris: isOS(solaris),
|
|
882
|
-
isFreeBSD: isOS(freebsd),
|
|
883
|
-
isChromeOS: isOS(chromeos)
|
|
884
|
-
};
|
|
885
|
-
};
|
|
886
|
-
const OperatingSystem = {
|
|
887
|
-
unknown,
|
|
888
|
-
nu,
|
|
889
|
-
windows: constant(windows),
|
|
890
|
-
ios: constant(ios),
|
|
891
|
-
android: constant(android),
|
|
892
|
-
linux: constant(linux),
|
|
893
|
-
macos: constant(macos),
|
|
894
|
-
solaris: constant(solaris),
|
|
895
|
-
freebsd: constant(freebsd),
|
|
896
|
-
chromeos: constant(chromeos)
|
|
897
|
-
};
|
|
898
|
-
|
|
899
|
-
const detect$1 = (userAgent, userAgentDataOpt, mediaMatch) => {
|
|
900
|
-
const browsers = PlatformInfo.browsers();
|
|
901
|
-
const oses = PlatformInfo.oses();
|
|
902
|
-
const browser = userAgentDataOpt.bind((userAgentData) => detectBrowser$1(browsers, userAgentData))
|
|
903
|
-
.orThunk(() => detectBrowser(browsers, userAgent))
|
|
904
|
-
.fold(Browser.unknown, Browser.nu);
|
|
905
|
-
const os = detectOs(oses, userAgent).fold(OperatingSystem.unknown, OperatingSystem.nu);
|
|
906
|
-
const deviceType = DeviceType(os, browser, userAgent, mediaMatch);
|
|
907
|
-
return {
|
|
908
|
-
browser,
|
|
909
|
-
os,
|
|
910
|
-
deviceType
|
|
911
|
-
};
|
|
912
|
-
};
|
|
913
|
-
const PlatformDetection = {
|
|
914
|
-
detect: detect$1
|
|
915
|
-
};
|
|
916
|
-
|
|
917
|
-
const mediaMatch = (query) => window.matchMedia(query).matches;
|
|
918
|
-
// IMPORTANT: Must be in a thunk, otherwise rollup thinks calling this immediately
|
|
919
|
-
// causes side effects and won't tree shake this away
|
|
920
|
-
// Note: navigator.userAgentData is not part of the native typescript types yet
|
|
921
|
-
let platform = cached(() => PlatformDetection.detect(window.navigator.userAgent, Optional.from((window.navigator.userAgentData)), mediaMatch));
|
|
922
|
-
const detect = () => platform();
|
|
923
|
-
|
|
924
|
-
const unsafe = (name, scope) => {
|
|
925
|
-
return resolve(name, scope);
|
|
926
|
-
};
|
|
927
|
-
const getOrDie = (name, scope) => {
|
|
928
|
-
const actual = unsafe(name, scope);
|
|
929
|
-
if (actual === undefined || actual === null) {
|
|
930
|
-
throw new Error(name + ' not available on this browser');
|
|
931
|
-
}
|
|
932
|
-
return actual;
|
|
933
|
-
};
|
|
934
|
-
|
|
935
|
-
const getPrototypeOf = Object.getPrototypeOf;
|
|
936
|
-
/*
|
|
937
|
-
* IE9 and above
|
|
938
|
-
*
|
|
939
|
-
* MDN no use on this one, but here's the link anyway:
|
|
940
|
-
* https://developer.mozilla.org/en/docs/Web/API/HTMLElement
|
|
941
|
-
*/
|
|
942
|
-
const sandHTMLElement = (scope) => {
|
|
943
|
-
return getOrDie('HTMLElement', scope);
|
|
944
|
-
};
|
|
945
|
-
const isPrototypeOf = (x) => {
|
|
946
|
-
// use Resolve to get the window object for x and just return undefined if it can't find it.
|
|
947
|
-
// undefined scope later triggers using the global window.
|
|
948
|
-
const scope = resolve('ownerDocument.defaultView', x);
|
|
949
|
-
// TINY-7374: We can't rely on looking at the owner window HTMLElement as the element may have
|
|
950
|
-
// been constructed in a different window and then appended to the current window document.
|
|
951
|
-
return isObject(x) && (sandHTMLElement(scope).prototype.isPrototypeOf(x) || /^HTML\w*Element$/.test(getPrototypeOf(x).constructor.name));
|
|
952
|
-
};
|
|
953
|
-
|
|
954
|
-
const type = (element) => element.dom.nodeType;
|
|
955
|
-
const isType = (t) => (element) => type(element) === t;
|
|
956
|
-
const isHTMLElement = (element) => isElement(element) && isPrototypeOf(element.dom);
|
|
957
|
-
const isElement = isType(ELEMENT);
|
|
958
|
-
const isText = isType(TEXT);
|
|
959
|
-
const isDocumentFragment = isType(DOCUMENT_FRAGMENT);
|
|
960
|
-
|
|
961
|
-
/**
|
|
962
|
-
* The document associated with the current element
|
|
963
|
-
* NOTE: this will throw if the owner is null.
|
|
964
|
-
*/
|
|
965
|
-
const owner = (element) => SugarElement.fromDom(element.dom.ownerDocument);
|
|
966
|
-
const parent = (element) => Optional.from(element.dom.parentNode).map(SugarElement.fromDom);
|
|
967
|
-
const parents = (element, isRoot) => {
|
|
968
|
-
const stop = isFunction(isRoot) ? isRoot : never;
|
|
969
|
-
// This is used a *lot* so it needs to be performant, not recursive
|
|
970
|
-
let dom = element.dom;
|
|
971
|
-
const ret = [];
|
|
972
|
-
while (dom.parentNode !== null && dom.parentNode !== undefined) {
|
|
973
|
-
const rawParent = dom.parentNode;
|
|
974
|
-
const p = SugarElement.fromDom(rawParent);
|
|
975
|
-
ret.push(p);
|
|
976
|
-
if (stop(p) === true) {
|
|
977
|
-
break;
|
|
978
|
-
}
|
|
979
|
-
else {
|
|
980
|
-
dom = rawParent;
|
|
981
|
-
}
|
|
982
|
-
}
|
|
983
|
-
return ret;
|
|
984
|
-
};
|
|
985
|
-
const siblings$2 = (element) => {
|
|
986
|
-
// TODO: Refactor out children so we can just not add self instead of filtering afterwards
|
|
987
|
-
const filterSelf = (elements) => filter$1(elements, (x) => !eq(element, x));
|
|
988
|
-
return parent(element).map(children).map(filterSelf).getOr([]);
|
|
989
|
-
};
|
|
990
|
-
const nextSibling = (element) => Optional.from(element.dom.nextSibling).map(SugarElement.fromDom);
|
|
991
|
-
const children = (element) => map(element.dom.childNodes, SugarElement.fromDom);
|
|
992
|
-
|
|
993
|
-
/**
|
|
994
|
-
* Is the element a ShadowRoot?
|
|
995
|
-
*
|
|
996
|
-
* Note: this is insufficient to test if any element is a shadow root, but it is sufficient to differentiate between
|
|
997
|
-
* a Document and a ShadowRoot.
|
|
998
|
-
*/
|
|
999
|
-
const isShadowRoot = (dos) => isDocumentFragment(dos) && isNonNullable(dos.dom.host);
|
|
1000
|
-
const getRootNode = (e) => SugarElement.fromDom(e.dom.getRootNode());
|
|
1001
|
-
/** If this element is in a ShadowRoot, return it. */
|
|
1002
|
-
const getShadowRoot = (e) => {
|
|
1003
|
-
const r = getRootNode(e);
|
|
1004
|
-
return isShadowRoot(r) ? Optional.some(r) : Optional.none();
|
|
1005
|
-
};
|
|
1006
|
-
/** Return the host of a ShadowRoot.
|
|
1007
|
-
*
|
|
1008
|
-
* This function will throw if Shadow DOM is unsupported in the browser, or if the host is null.
|
|
1009
|
-
* If you actually have a ShadowRoot, this shouldn't happen.
|
|
1010
|
-
*/
|
|
1011
|
-
const getShadowHost = (e) => SugarElement.fromDom(e.dom.host);
|
|
1012
|
-
/**
|
|
1013
|
-
* When Events bubble up through a ShadowRoot, the browser changes the target to be the shadow host.
|
|
1014
|
-
* This function gets the "original" event target if possible.
|
|
1015
|
-
* This only works if the shadow tree is open - if the shadow tree is closed, event.target is returned.
|
|
1016
|
-
* See: https://developers.google.com/web/fundamentals/web-components/shadowdom#events
|
|
1017
|
-
*/
|
|
1018
|
-
const getOriginalEventTarget = (event) => {
|
|
1019
|
-
if (isNonNullable(event.target)) {
|
|
1020
|
-
const el = SugarElement.fromDom(event.target);
|
|
1021
|
-
if (isElement(el) && isOpenShadowHost(el)) {
|
|
1022
|
-
// When target element is inside Shadow DOM we need to take first element from composedPath
|
|
1023
|
-
// otherwise we'll get Shadow Root parent, not actual target element.
|
|
1024
|
-
if (event.composed && event.composedPath) {
|
|
1025
|
-
const composedPath = event.composedPath();
|
|
1026
|
-
if (composedPath) {
|
|
1027
|
-
return head(composedPath);
|
|
1028
|
-
}
|
|
1029
|
-
}
|
|
1030
|
-
}
|
|
1031
|
-
}
|
|
1032
|
-
return Optional.from(event.target);
|
|
1033
|
-
};
|
|
1034
|
-
/** Return true if the element is a host of an open shadow root.
|
|
1035
|
-
* Return false if the element is a host of a closed shadow root, or if the element is not a host.
|
|
1036
|
-
*/
|
|
1037
|
-
const isOpenShadowHost = (element) => isNonNullable(element.dom.shadowRoot);
|
|
1038
|
-
|
|
1039
|
-
const mkEvent = (target, x, y, stop, prevent, kill, raw) => ({
|
|
1040
|
-
target,
|
|
1041
|
-
x,
|
|
1042
|
-
y,
|
|
1043
|
-
stop,
|
|
1044
|
-
prevent,
|
|
1045
|
-
kill,
|
|
1046
|
-
raw
|
|
1047
|
-
});
|
|
1048
|
-
/** Wraps an Event in an EventArgs structure.
|
|
1049
|
-
* The returned EventArgs structure has its target set to the "original" target if possible.
|
|
1050
|
-
* See SugarShadowDom.getOriginalEventTarget
|
|
1051
|
-
*/
|
|
1052
|
-
const fromRawEvent = (rawEvent) => {
|
|
1053
|
-
const target = SugarElement.fromDom(getOriginalEventTarget(rawEvent).getOr(rawEvent.target));
|
|
1054
|
-
const stop = () => rawEvent.stopPropagation();
|
|
1055
|
-
const prevent = () => rawEvent.preventDefault();
|
|
1056
|
-
const kill = compose(prevent, stop); // more of a sequence than a compose, but same effect
|
|
1057
|
-
// FIX: Don't just expose the raw event. Need to identify what needs standardisation.
|
|
1058
|
-
return mkEvent(target, rawEvent.clientX, rawEvent.clientY, stop, prevent, kill, rawEvent);
|
|
1059
|
-
};
|
|
1060
|
-
const handle = (filter, handler) => (rawEvent) => {
|
|
1061
|
-
if (filter(rawEvent)) {
|
|
1062
|
-
handler(fromRawEvent(rawEvent));
|
|
1063
|
-
}
|
|
1064
|
-
};
|
|
1065
|
-
const binder = (element, event, filter, handler, useCapture) => {
|
|
1066
|
-
const wrapped = handle(filter, handler);
|
|
1067
|
-
// IE9 minimum
|
|
1068
|
-
element.dom.addEventListener(event, wrapped, useCapture);
|
|
1069
|
-
return {
|
|
1070
|
-
unbind: curry(unbind, element, event, wrapped, useCapture)
|
|
1071
|
-
};
|
|
1072
|
-
};
|
|
1073
|
-
const bind$2 = (element, event, filter, handler) => binder(element, event, filter, handler, false);
|
|
1074
|
-
const unbind = (element, event, handler, useCapture) => {
|
|
1075
|
-
// IE9 minimum
|
|
1076
|
-
element.dom.removeEventListener(event, handler, useCapture);
|
|
1077
|
-
};
|
|
1078
|
-
|
|
1079
|
-
const filter = always; // no filter on plain DomEvents
|
|
1080
|
-
const bind$1 = (element, event, handler) => bind$2(element, event, filter, handler);
|
|
1081
|
-
|
|
1082
|
-
const rawSet = (dom, key, value) => {
|
|
1083
|
-
/*
|
|
1084
|
-
* JQuery coerced everything to a string, and silently did nothing on text node/null/undefined.
|
|
1085
|
-
*
|
|
1086
|
-
* We fail on those invalid cases, only allowing numbers and booleans.
|
|
1087
|
-
*/
|
|
1088
|
-
if (isString(value) || isBoolean(value) || isNumber(value)) {
|
|
1089
|
-
dom.setAttribute(key, value + '');
|
|
1090
|
-
}
|
|
1091
|
-
else {
|
|
1092
|
-
// eslint-disable-next-line no-console
|
|
1093
|
-
console.error('Invalid call to Attribute.set. Key ', key, ':: Value ', value, ':: Element ', dom);
|
|
1094
|
-
throw new Error('Attribute value was not simple');
|
|
1095
|
-
}
|
|
1096
|
-
};
|
|
1097
|
-
const set$1 = (element, key, value) => {
|
|
1098
|
-
rawSet(element.dom, key, value);
|
|
1099
|
-
};
|
|
1100
|
-
const get$3 = (element, key) => {
|
|
1101
|
-
const v = element.dom.getAttribute(key);
|
|
1102
|
-
// undefined is the more appropriate value for JS, and this matches JQuery
|
|
1103
|
-
return v === null ? undefined : v;
|
|
1104
|
-
};
|
|
1105
|
-
const remove = (element, key) => {
|
|
1106
|
-
element.dom.removeAttribute(key);
|
|
1107
|
-
};
|
|
1108
|
-
|
|
1109
|
-
// some elements, such as mathml, don't have style attributes
|
|
1110
|
-
// others, such as angular elements, have style attributes that aren't a CSSStyleDeclaration
|
|
1111
|
-
const isSupported = (dom) => dom.style !== undefined && isFunction(dom.style.getPropertyValue);
|
|
1112
|
-
|
|
1113
|
-
// Node.contains() is very, very, very good performance
|
|
1114
|
-
// http://jsperf.com/closest-vs-contains/5
|
|
1115
|
-
const inBody = (element) => {
|
|
1116
|
-
// Technically this is only required on IE, where contains() returns false for text nodes.
|
|
1117
|
-
// But it's cheap enough to run everywhere and Sugar doesn't have platform detection (yet).
|
|
1118
|
-
const dom = isText(element) ? element.dom.parentNode : element.dom;
|
|
1119
|
-
// use ownerDocument.body to ensure this works inside iframes.
|
|
1120
|
-
// Normally contains is bad because an element "contains" itself, but here we want that.
|
|
1121
|
-
if (dom === undefined || dom === null || dom.ownerDocument === null) {
|
|
1122
|
-
return false;
|
|
1123
|
-
}
|
|
1124
|
-
const doc = dom.ownerDocument;
|
|
1125
|
-
return getShadowRoot(SugarElement.fromDom(dom)).fold(() => doc.body.contains(dom), compose1(inBody, getShadowHost));
|
|
1126
|
-
};
|
|
1127
|
-
const getBody = (doc) => {
|
|
1128
|
-
const b = doc.dom.body;
|
|
1129
|
-
if (b === null || b === undefined) {
|
|
1130
|
-
throw new Error('Body is not available yet');
|
|
1131
|
-
}
|
|
1132
|
-
return SugarElement.fromDom(b);
|
|
1133
|
-
};
|
|
1134
|
-
|
|
1135
|
-
const internalSet = (dom, property, value) => {
|
|
1136
|
-
// This is going to hurt. Apologies.
|
|
1137
|
-
// JQuery coerces numbers to pixels for certain property names, and other times lets numbers through.
|
|
1138
|
-
// we're going to be explicit; strings only.
|
|
1139
|
-
if (!isString(value)) {
|
|
1140
|
-
// eslint-disable-next-line no-console
|
|
1141
|
-
console.error('Invalid call to CSS.set. Property ', property, ':: Value ', value, ':: Element ', dom);
|
|
1142
|
-
throw new Error('CSS value must be a string: ' + value);
|
|
1143
|
-
}
|
|
1144
|
-
// removed: support for dom().style[property] where prop is camel case instead of normal property name
|
|
1145
|
-
if (isSupported(dom)) {
|
|
1146
|
-
dom.style.setProperty(property, value);
|
|
1147
|
-
}
|
|
1148
|
-
};
|
|
1149
|
-
const set = (element, property, value) => {
|
|
1150
|
-
const dom = element.dom;
|
|
1151
|
-
internalSet(dom, property, value);
|
|
1152
|
-
};
|
|
1153
|
-
const setAll = (element, css) => {
|
|
1154
|
-
const dom = element.dom;
|
|
1155
|
-
each(css, (v, k) => {
|
|
1156
|
-
internalSet(dom, k, v);
|
|
1157
|
-
});
|
|
1158
|
-
};
|
|
1159
|
-
/*
|
|
1160
|
-
* NOTE: For certain properties, this returns the "used value" which is subtly different to the "computed value" (despite calling getComputedStyle).
|
|
1161
|
-
* Blame CSS 2.0.
|
|
1162
|
-
*
|
|
1163
|
-
* https://developer.mozilla.org/en-US/docs/Web/CSS/used_value
|
|
1164
|
-
*/
|
|
1165
|
-
const get$2 = (element, property) => {
|
|
1166
|
-
const dom = element.dom;
|
|
1167
|
-
/*
|
|
1168
|
-
* IE9 and above per
|
|
1169
|
-
* https://developer.mozilla.org/en/docs/Web/API/window.getComputedStyle
|
|
1170
|
-
*
|
|
1171
|
-
* Not in numerosity, because it doesn't memoize and looking this up dynamically in performance critical code would be horrendous.
|
|
1172
|
-
*
|
|
1173
|
-
* JQuery has some magic here for IE popups, but we don't really need that.
|
|
1174
|
-
* It also uses element.ownerDocument.defaultView to handle iframes but that hasn't been required since FF 3.6.
|
|
1175
|
-
*/
|
|
1176
|
-
const styles = window.getComputedStyle(dom);
|
|
1177
|
-
const r = styles.getPropertyValue(property);
|
|
1178
|
-
// jquery-ism: If r is an empty string, check that the element is not in a document. If it isn't, return the raw value.
|
|
1179
|
-
// Turns out we do this a lot.
|
|
1180
|
-
return (r === '' && !inBody(element)) ? getUnsafeProperty(dom, property) : r;
|
|
1181
|
-
};
|
|
1182
|
-
// removed: support for dom().style[property] where prop is camel case instead of normal property name
|
|
1183
|
-
// empty string is what the browsers (IE11 and Chrome) return when the propertyValue doesn't exists.
|
|
1184
|
-
const getUnsafeProperty = (dom, property) => isSupported(dom) ? dom.style.getPropertyValue(property) : '';
|
|
1185
|
-
|
|
1186
|
-
const r = (left, top) => {
|
|
1187
|
-
const translate = (x, y) => r(left + x, top + y);
|
|
1188
|
-
return {
|
|
1189
|
-
left,
|
|
1190
|
-
top,
|
|
1191
|
-
translate
|
|
1192
|
-
};
|
|
1193
|
-
};
|
|
1194
|
-
// tslint:disable-next-line:variable-name
|
|
1195
|
-
const SugarPosition = r;
|
|
1196
|
-
|
|
1197
|
-
// get scroll position (x,y) relative to document _doc (or global if not supplied)
|
|
1198
|
-
const get$1 = (_DOC) => {
|
|
1199
|
-
const doc = _DOC !== undefined ? _DOC.dom : document;
|
|
1200
|
-
// ASSUMPTION: This is for cross-browser support, body works for Safari & EDGE, and when we have an iframe body scroller
|
|
1201
|
-
const x = doc.body.scrollLeft || doc.documentElement.scrollLeft;
|
|
1202
|
-
const y = doc.body.scrollTop || doc.documentElement.scrollTop;
|
|
1203
|
-
return SugarPosition(x, y);
|
|
1204
|
-
};
|
|
1205
|
-
|
|
1206
|
-
// IE11 Can return undefined for a classList on elements such as math, so we make sure it's not undefined before attempting to use it.
|
|
1207
|
-
const supports = (element) => element.dom.classList !== undefined;
|
|
1208
|
-
|
|
1209
|
-
const has = (element, clazz) => supports(element) && element.dom.classList.contains(clazz);
|
|
1210
|
-
|
|
1211
|
-
const ancestors$1 = (scope, predicate, isRoot) => filter$1(parents(scope, isRoot), predicate);
|
|
1212
|
-
const siblings$1 = (scope, predicate) => filter$1(siblings$2(scope), predicate);
|
|
1213
|
-
|
|
1214
|
-
const all = (selector) => all$1(selector);
|
|
1215
|
-
// For all of the following:
|
|
1216
|
-
//
|
|
1217
|
-
// jQuery does siblings of firstChild. IE9+ supports scope.dom.children (similar to Traverse.children but elements only).
|
|
1218
|
-
// Traverse should also do this (but probably not by default).
|
|
1219
|
-
//
|
|
1220
|
-
const ancestors = (scope, selector, isRoot) =>
|
|
1221
|
-
// It may surprise you to learn this is exactly what JQuery does
|
|
1222
|
-
// TODO: Avoid all this wrapping and unwrapping
|
|
1223
|
-
ancestors$1(scope, (e) => is(e, selector), isRoot);
|
|
1224
|
-
const siblings = (scope, selector) =>
|
|
1225
|
-
// It may surprise you to learn this is exactly what JQuery does
|
|
1226
|
-
// TODO: Avoid all the wrapping and unwrapping
|
|
1227
|
-
siblings$1(scope, (e) => is(e, selector));
|
|
1228
|
-
|
|
1229
|
-
const get = (_win) => {
|
|
1230
|
-
const win = _win === undefined ? window : _win;
|
|
1231
|
-
if (detect().browser.isFirefox()) {
|
|
1232
|
-
// TINY-7984: Firefox 91 is returning incorrect values for visualViewport.pageTop, so disable it for now
|
|
1233
|
-
return Optional.none();
|
|
1234
|
-
}
|
|
1235
|
-
else {
|
|
1236
|
-
return Optional.from(win.visualViewport);
|
|
1237
|
-
}
|
|
1238
|
-
};
|
|
1239
|
-
const bounds = (x, y, width, height) => ({
|
|
1240
|
-
x,
|
|
1241
|
-
y,
|
|
1242
|
-
width,
|
|
1243
|
-
height,
|
|
1244
|
-
right: x + width,
|
|
1245
|
-
bottom: y + height
|
|
1246
|
-
});
|
|
1247
|
-
const getBounds = (_win) => {
|
|
1248
|
-
const win = _win === undefined ? window : _win;
|
|
1249
|
-
const doc = win.document;
|
|
1250
|
-
const scroll = get$1(SugarElement.fromDom(doc));
|
|
1251
|
-
return get(win).fold(() => {
|
|
1252
|
-
const html = win.document.documentElement;
|
|
1253
|
-
// Don't use window.innerWidth/innerHeight here, as we don't want to include scrollbars
|
|
1254
|
-
// since the right/bottom position is based on the edge of the scrollbar not the window
|
|
1255
|
-
const width = html.clientWidth;
|
|
1256
|
-
const height = html.clientHeight;
|
|
1257
|
-
return bounds(scroll.left, scroll.top, width, height);
|
|
1258
|
-
}, (visualViewport) =>
|
|
1259
|
-
// iOS doesn't update the pageTop/pageLeft when element.scrollIntoView() is called, so we need to fallback to the
|
|
1260
|
-
// scroll position which will always be less than the page top/left values when page top/left are accurate/correct.
|
|
1261
|
-
bounds(Math.max(visualViewport.pageLeft, scroll.left), Math.max(visualViewport.pageTop, scroll.top), visualViewport.width, visualViewport.height));
|
|
1262
|
-
};
|
|
1263
|
-
const bind = (name, callback, _win) => get(_win).map((visualViewport) => {
|
|
1264
|
-
const handler = (e) => callback(fromRawEvent(e));
|
|
1265
|
-
visualViewport.addEventListener(name, handler);
|
|
1266
|
-
return {
|
|
1267
|
-
unbind: () => visualViewport.removeEventListener(name, handler)
|
|
1268
|
-
};
|
|
1269
|
-
}).getOrThunk(() => ({
|
|
1270
|
-
unbind: noop
|
|
1271
|
-
}));
|
|
1272
|
-
|
|
1273
|
-
var global$2 = tinymce.util.Tools.resolve('tinymce.dom.DOMUtils');
|
|
1274
|
-
|
|
1275
|
-
var global$1 = tinymce.util.Tools.resolve('tinymce.Env');
|
|
1276
|
-
|
|
1277
|
-
const fireFullscreenStateChanged = (editor, state) => {
|
|
1278
|
-
editor.dispatch('FullscreenStateChanged', { state });
|
|
1279
|
-
editor.dispatch('ResizeEditor');
|
|
1280
|
-
};
|
|
1281
|
-
|
|
1282
|
-
const option = (name) => (editor) => editor.options.get(name);
|
|
1283
|
-
const register$2 = (editor) => {
|
|
1284
|
-
const registerOption = editor.options.register;
|
|
1285
|
-
registerOption('fullscreen_native', {
|
|
1286
|
-
processor: 'boolean',
|
|
1287
|
-
default: false
|
|
1288
|
-
});
|
|
1289
|
-
};
|
|
1290
|
-
const getFullscreenNative = option('fullscreen_native');
|
|
1291
|
-
|
|
1292
|
-
const getFullscreenRoot = (editor) => {
|
|
1293
|
-
const elem = SugarElement.fromDom(editor.getElement());
|
|
1294
|
-
return getShadowRoot(elem).map(getShadowHost)
|
|
1295
|
-
.getOrThunk(() => getBody(owner(elem)));
|
|
1296
|
-
};
|
|
1297
|
-
const getFullscreenElement = (root) => {
|
|
1298
|
-
if (root.fullscreenElement !== undefined) {
|
|
1299
|
-
return root.fullscreenElement;
|
|
1300
|
-
}
|
|
1301
|
-
else if (root.msFullscreenElement !== undefined) {
|
|
1302
|
-
return root.msFullscreenElement;
|
|
1303
|
-
}
|
|
1304
|
-
else if (root.webkitFullscreenElement !== undefined) {
|
|
1305
|
-
return root.webkitFullscreenElement;
|
|
1306
|
-
}
|
|
1307
|
-
else {
|
|
1308
|
-
return null;
|
|
1309
|
-
}
|
|
1310
|
-
};
|
|
1311
|
-
const getFullscreenchangeEventName = () => {
|
|
1312
|
-
if (document.fullscreenElement !== undefined) {
|
|
1313
|
-
return 'fullscreenchange';
|
|
1314
|
-
}
|
|
1315
|
-
else if (document.msFullscreenElement !== undefined) {
|
|
1316
|
-
return 'MSFullscreenChange'; // warning, seems to be case sensitive
|
|
1317
|
-
}
|
|
1318
|
-
else if (document.webkitFullscreenElement !== undefined) {
|
|
1319
|
-
return 'webkitfullscreenchange';
|
|
1320
|
-
}
|
|
1321
|
-
else {
|
|
1322
|
-
return 'fullscreenchange';
|
|
1323
|
-
}
|
|
1324
|
-
};
|
|
1325
|
-
const requestFullscreen = (sugarElem) => {
|
|
1326
|
-
const elem = sugarElem.dom;
|
|
1327
|
-
if (elem.requestFullscreen) {
|
|
1328
|
-
// eslint-disable-next-line @typescript-eslint/no-floating-promises
|
|
1329
|
-
elem.requestFullscreen();
|
|
1330
|
-
}
|
|
1331
|
-
else if (elem.msRequestFullscreen) {
|
|
1332
|
-
elem.msRequestFullscreen();
|
|
1333
|
-
}
|
|
1334
|
-
else if (elem.webkitRequestFullScreen) {
|
|
1335
|
-
elem.webkitRequestFullScreen();
|
|
1336
|
-
}
|
|
1337
|
-
};
|
|
1338
|
-
const exitFullscreen = (sugarDoc) => {
|
|
1339
|
-
const doc = sugarDoc.dom;
|
|
1340
|
-
if (doc.exitFullscreen) {
|
|
1341
|
-
// eslint-disable-next-line @typescript-eslint/no-floating-promises
|
|
1342
|
-
doc.exitFullscreen();
|
|
1343
|
-
}
|
|
1344
|
-
else if (doc.msExitFullscreen) {
|
|
1345
|
-
doc.msExitFullscreen();
|
|
1346
|
-
}
|
|
1347
|
-
else if (doc.webkitCancelFullScreen) {
|
|
1348
|
-
doc.webkitCancelFullScreen();
|
|
1349
|
-
}
|
|
1350
|
-
};
|
|
1351
|
-
const isFullscreenElement = (elem) => elem.dom === getFullscreenElement(owner(elem).dom);
|
|
1352
|
-
|
|
1353
|
-
const attr = 'data-ephox-mobile-fullscreen-style';
|
|
1354
|
-
const siblingStyles = 'display:none!important;';
|
|
1355
|
-
const ancestorPosition = 'position:absolute!important;';
|
|
1356
|
-
// TINY-3407 ancestors need 'height:100%!important;overflow:visible!important;' to prevent collapsed ancestors hiding the editor
|
|
1357
|
-
const ancestorStyles = 'top:0!important;left:0!important;margin:0!important;padding:0!important;width:100%!important;height:100%!important;overflow:visible!important;';
|
|
1358
|
-
const bgFallback = 'background-color:rgb(255,255,255)!important;';
|
|
1359
|
-
const isAndroid = global$1.os.isAndroid();
|
|
1360
|
-
const matchColor = (editorBody) => {
|
|
1361
|
-
// in iOS you can overscroll, sometimes when you overscroll you can reveal the bgcolor of an element beneath,
|
|
1362
|
-
// by matching the bg color and clobbering ensures any reveals are 'camouflaged' the same color
|
|
1363
|
-
const color = get$2(editorBody, 'background-color');
|
|
1364
|
-
return (color !== undefined && color !== '') ? 'background-color:' + color + '!important' : bgFallback;
|
|
1365
|
-
};
|
|
1366
|
-
// We clobber all tags, direct ancestors to the editorBody get ancestorStyles, everything else gets siblingStyles
|
|
1367
|
-
const clobberStyles = (dom, container, editorBody) => {
|
|
1368
|
-
const gatherSiblings = (element) => {
|
|
1369
|
-
return siblings(element, '*:not(.tox-silver-sink)');
|
|
1370
|
-
};
|
|
1371
|
-
const clobber = (clobberStyle) => (element) => {
|
|
1372
|
-
const styles = get$3(element, 'style');
|
|
1373
|
-
const backup = styles === undefined ? 'no-styles' : styles.trim();
|
|
1374
|
-
if (backup === clobberStyle) {
|
|
1375
|
-
return;
|
|
1376
|
-
}
|
|
1377
|
-
else {
|
|
1378
|
-
set$1(element, attr, backup);
|
|
1379
|
-
setAll(element, dom.parseStyle(clobberStyle));
|
|
1380
|
-
}
|
|
1381
|
-
};
|
|
1382
|
-
const ancestors$1 = ancestors(container, '*');
|
|
1383
|
-
const siblings$1 = bind$3(ancestors$1, gatherSiblings);
|
|
1384
|
-
const bgColor = matchColor(editorBody);
|
|
1385
|
-
/* NOTE: This assumes that container has no siblings itself */
|
|
1386
|
-
each$1(siblings$1, clobber(siblingStyles));
|
|
1387
|
-
each$1(ancestors$1, clobber(ancestorPosition + ancestorStyles + bgColor));
|
|
1388
|
-
// position absolute on the outer-container breaks Android flex layout
|
|
1389
|
-
const containerStyles = isAndroid === true ? '' : ancestorPosition;
|
|
1390
|
-
clobber(containerStyles + ancestorStyles + bgColor)(container);
|
|
1391
|
-
};
|
|
1392
|
-
const restoreStyles = (dom) => {
|
|
1393
|
-
const clobberedEls = all('[' + attr + ']');
|
|
1394
|
-
each$1(clobberedEls, (element) => {
|
|
1395
|
-
const restore = get$3(element, attr);
|
|
1396
|
-
if (restore && restore !== 'no-styles') {
|
|
1397
|
-
setAll(element, dom.parseStyle(restore));
|
|
1398
|
-
}
|
|
1399
|
-
else {
|
|
1400
|
-
remove(element, 'style');
|
|
1401
|
-
}
|
|
1402
|
-
remove(element, attr);
|
|
1403
|
-
});
|
|
1404
|
-
};
|
|
1405
|
-
|
|
1406
|
-
const DOM = global$2.DOM;
|
|
1407
|
-
const getScrollPos = () => getBounds(window);
|
|
1408
|
-
const setScrollPos = (pos) => window.scrollTo(pos.x, pos.y);
|
|
1409
|
-
const viewportUpdate = get().fold(() => ({ bind: noop, unbind: noop }), (visualViewport) => {
|
|
1410
|
-
const editorContainer = value();
|
|
1411
|
-
const resizeBinder = unbindable();
|
|
1412
|
-
const scrollBinder = unbindable();
|
|
1413
|
-
const refreshScroll = () => {
|
|
1414
|
-
document.body.scrollTop = 0;
|
|
1415
|
-
document.documentElement.scrollTop = 0;
|
|
1416
|
-
};
|
|
1417
|
-
const refreshVisualViewport = () => {
|
|
1418
|
-
window.requestAnimationFrame(() => {
|
|
1419
|
-
editorContainer.on((container) => setAll(container, {
|
|
1420
|
-
top: visualViewport.offsetTop + 'px',
|
|
1421
|
-
left: visualViewport.offsetLeft + 'px',
|
|
1422
|
-
height: visualViewport.height + 'px',
|
|
1423
|
-
width: visualViewport.width + 'px'
|
|
1424
|
-
}));
|
|
1425
|
-
});
|
|
1426
|
-
};
|
|
1427
|
-
const update = first(() => {
|
|
1428
|
-
refreshScroll();
|
|
1429
|
-
refreshVisualViewport();
|
|
1430
|
-
}, 50);
|
|
1431
|
-
const bind$1 = (element) => {
|
|
1432
|
-
editorContainer.set(element);
|
|
1433
|
-
update.throttle();
|
|
1434
|
-
resizeBinder.set(bind('resize', update.throttle));
|
|
1435
|
-
scrollBinder.set(bind('scroll', update.throttle));
|
|
1436
|
-
};
|
|
1437
|
-
const unbind = () => {
|
|
1438
|
-
editorContainer.on(() => {
|
|
1439
|
-
resizeBinder.clear();
|
|
1440
|
-
scrollBinder.clear();
|
|
1441
|
-
});
|
|
1442
|
-
editorContainer.clear();
|
|
1443
|
-
};
|
|
1444
|
-
return {
|
|
1445
|
-
bind: bind$1,
|
|
1446
|
-
unbind
|
|
1447
|
-
};
|
|
1448
|
-
});
|
|
1449
|
-
const toggleFullscreen = (editor, fullscreenState) => {
|
|
1450
|
-
const body = document.body;
|
|
1451
|
-
const documentElement = document.documentElement;
|
|
1452
|
-
const editorContainer = editor.getContainer();
|
|
1453
|
-
const editorContainerS = SugarElement.fromDom(editorContainer);
|
|
1454
|
-
const sinkContainerS = nextSibling(editorContainerS)
|
|
1455
|
-
.filter((elm) => isHTMLElement(elm) && has(elm, 'tox-silver-sink'));
|
|
1456
|
-
const fullscreenRoot = getFullscreenRoot(editor);
|
|
1457
|
-
const fullscreenInfo = fullscreenState.get();
|
|
1458
|
-
const editorBody = SugarElement.fromDom(editor.getBody());
|
|
1459
|
-
const isTouch = global$1.deviceType.isTouch();
|
|
1460
|
-
const editorContainerStyle = editorContainer.style;
|
|
1461
|
-
const iframe = editor.iframeElement;
|
|
1462
|
-
const iframeStyle = iframe?.style;
|
|
1463
|
-
const handleClasses = (handler) => {
|
|
1464
|
-
handler(body, 'tox-fullscreen');
|
|
1465
|
-
handler(documentElement, 'tox-fullscreen');
|
|
1466
|
-
handler(editorContainer, 'tox-fullscreen');
|
|
1467
|
-
getShadowRoot(editorContainerS)
|
|
1468
|
-
.map((root) => getShadowHost(root).dom)
|
|
1469
|
-
.each((host) => {
|
|
1470
|
-
handler(host, 'tox-fullscreen');
|
|
1471
|
-
handler(host, 'tox-shadowhost');
|
|
1472
|
-
});
|
|
1473
|
-
};
|
|
1474
|
-
const cleanup = () => {
|
|
1475
|
-
if (isTouch) {
|
|
1476
|
-
restoreStyles(editor.dom);
|
|
1477
|
-
}
|
|
1478
|
-
handleClasses(DOM.removeClass);
|
|
1479
|
-
viewportUpdate.unbind();
|
|
1480
|
-
Optional.from(fullscreenState.get()).each((info) => info.fullscreenChangeHandler.unbind());
|
|
1481
|
-
};
|
|
1482
|
-
if (!fullscreenInfo) {
|
|
1483
|
-
const fullscreenChangeHandler = bind$1(owner(fullscreenRoot), getFullscreenchangeEventName(), (_evt) => {
|
|
1484
|
-
if (getFullscreenNative(editor)) {
|
|
1485
|
-
// if we have exited browser fullscreen with Escape then exit editor fullscreen too
|
|
1486
|
-
if (!isFullscreenElement(fullscreenRoot) && fullscreenState.get() !== null) {
|
|
1487
|
-
toggleFullscreen(editor, fullscreenState);
|
|
1488
|
-
}
|
|
1489
|
-
}
|
|
1490
|
-
});
|
|
1491
|
-
const newFullScreenInfo = {
|
|
1492
|
-
scrollPos: getScrollPos(),
|
|
1493
|
-
containerWidth: editorContainerStyle.width,
|
|
1494
|
-
containerHeight: editorContainerStyle.height,
|
|
1495
|
-
containerTop: editorContainerStyle.top,
|
|
1496
|
-
containerLeft: editorContainerStyle.left,
|
|
1497
|
-
iframeWidth: iframeStyle.width,
|
|
1498
|
-
iframeHeight: iframeStyle.height,
|
|
1499
|
-
fullscreenChangeHandler,
|
|
1500
|
-
sinkCssPosition: sinkContainerS.map((elm) => get$2(elm, 'position'))
|
|
1501
|
-
};
|
|
1502
|
-
if (isTouch) {
|
|
1503
|
-
clobberStyles(editor.dom, editorContainerS, editorBody);
|
|
1504
|
-
}
|
|
1505
|
-
iframeStyle.width = iframeStyle.height = '100%';
|
|
1506
|
-
editorContainerStyle.width = editorContainerStyle.height = '';
|
|
1507
|
-
handleClasses(DOM.addClass);
|
|
1508
|
-
sinkContainerS.each((elm) => {
|
|
1509
|
-
set(elm, 'position', 'fixed');
|
|
1510
|
-
});
|
|
1511
|
-
viewportUpdate.bind(editorContainerS);
|
|
1512
|
-
editor.on('remove', cleanup);
|
|
1513
|
-
fullscreenState.set(newFullScreenInfo);
|
|
1514
|
-
if (getFullscreenNative(editor)) {
|
|
1515
|
-
requestFullscreen(fullscreenRoot);
|
|
1516
|
-
}
|
|
1517
|
-
fireFullscreenStateChanged(editor, true);
|
|
1518
|
-
}
|
|
1519
|
-
else {
|
|
1520
|
-
fullscreenInfo.fullscreenChangeHandler.unbind();
|
|
1521
|
-
if (getFullscreenNative(editor) && isFullscreenElement(fullscreenRoot)) {
|
|
1522
|
-
exitFullscreen(owner(fullscreenRoot));
|
|
1523
|
-
}
|
|
1524
|
-
iframeStyle.width = fullscreenInfo.iframeWidth;
|
|
1525
|
-
iframeStyle.height = fullscreenInfo.iframeHeight;
|
|
1526
|
-
editorContainerStyle.width = fullscreenInfo.containerWidth;
|
|
1527
|
-
editorContainerStyle.height = fullscreenInfo.containerHeight;
|
|
1528
|
-
editorContainerStyle.top = fullscreenInfo.containerTop;
|
|
1529
|
-
editorContainerStyle.left = fullscreenInfo.containerLeft;
|
|
1530
|
-
lift2(sinkContainerS, fullscreenInfo.sinkCssPosition, (elm, val) => {
|
|
1531
|
-
set(elm, 'position', val);
|
|
1532
|
-
});
|
|
1533
|
-
cleanup();
|
|
1534
|
-
setScrollPos(fullscreenInfo.scrollPos);
|
|
1535
|
-
fullscreenState.set(null);
|
|
1536
|
-
fireFullscreenStateChanged(editor, false);
|
|
1537
|
-
editor.off('remove', cleanup);
|
|
1538
|
-
}
|
|
1539
|
-
};
|
|
1540
|
-
|
|
1541
|
-
const register$1 = (editor, fullscreenState) => {
|
|
1542
|
-
editor.addCommand('mceFullScreen', () => {
|
|
1543
|
-
toggleFullscreen(editor, fullscreenState);
|
|
1544
|
-
});
|
|
1545
|
-
};
|
|
1546
|
-
|
|
1547
|
-
var global = tinymce.util.Tools.resolve('tinymce.util.VK');
|
|
1548
|
-
|
|
1549
|
-
const setup = (editor, fullscreenState) => {
|
|
1550
|
-
editor.on('init', () => {
|
|
1551
|
-
editor.on('keydown', (e) => {
|
|
1552
|
-
if (e.keyCode === global.TAB && !(e.metaKey || e.ctrlKey) && fullscreenState.get()) {
|
|
1553
|
-
e.preventDefault();
|
|
1554
|
-
}
|
|
1555
|
-
});
|
|
1556
|
-
});
|
|
1557
|
-
};
|
|
1558
|
-
|
|
1559
|
-
const makeSetupHandler = (editor, fullscreenState) => (api) => {
|
|
1560
|
-
api.setActive(fullscreenState.get() !== null);
|
|
1561
|
-
const editorEventCallback = (e) => api.setActive(e.state);
|
|
1562
|
-
editor.on('FullscreenStateChanged', editorEventCallback);
|
|
1563
|
-
return () => editor.off('FullscreenStateChanged', editorEventCallback);
|
|
1564
|
-
};
|
|
1565
|
-
const register = (editor, fullscreenState) => {
|
|
1566
|
-
const onAction = () => editor.execCommand('mceFullScreen');
|
|
1567
|
-
editor.ui.registry.addToggleMenuItem('fullscreen', {
|
|
1568
|
-
text: 'Fullscreen',
|
|
1569
|
-
icon: 'fullscreen',
|
|
1570
|
-
shortcut: 'Meta+Shift+F',
|
|
1571
|
-
onAction,
|
|
1572
|
-
onSetup: makeSetupHandler(editor, fullscreenState),
|
|
1573
|
-
context: 'any'
|
|
1574
|
-
});
|
|
1575
|
-
editor.ui.registry.addToggleButton('fullscreen', {
|
|
1576
|
-
tooltip: 'Fullscreen',
|
|
1577
|
-
icon: 'fullscreen',
|
|
1578
|
-
onAction,
|
|
1579
|
-
onSetup: makeSetupHandler(editor, fullscreenState),
|
|
1580
|
-
shortcut: 'Meta+Shift+F',
|
|
1581
|
-
context: 'any'
|
|
1582
|
-
});
|
|
1583
|
-
};
|
|
1584
|
-
|
|
1585
|
-
var Plugin = () => {
|
|
1586
|
-
global$3.add('fullscreen', (editor) => {
|
|
1587
|
-
const fullscreenState = Cell(null);
|
|
1588
|
-
if (editor.inline) {
|
|
1589
|
-
return get$4(fullscreenState);
|
|
1590
|
-
}
|
|
1591
|
-
register$2(editor);
|
|
1592
|
-
register$1(editor, fullscreenState);
|
|
1593
|
-
register(editor, fullscreenState);
|
|
1594
|
-
setup(editor, fullscreenState);
|
|
1595
|
-
editor.addShortcut('Meta+Shift+F', '', 'mceFullScreen');
|
|
1596
|
-
return get$4(fullscreenState);
|
|
1597
|
-
});
|
|
1598
|
-
};
|
|
1599
|
-
|
|
1600
|
-
Plugin();
|
|
1601
|
-
/** *****
|
|
1602
|
-
* DO NOT EXPORT ANYTHING
|
|
1603
|
-
*
|
|
1604
|
-
* IF YOU DO ROLLUP WILL LEAVE A GLOBAL ON THE PAGE
|
|
1605
|
-
*******/
|
|
1606
|
-
|
|
1607
|
-
})();
|