@universal-ember/docs-support 0.8.0 → 0.9.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE.md +9 -0
- package/README.md +3 -21
- package/declarations/{article.gts.d.ts → article.d.ts} +1 -1
- package/declarations/article.d.ts.map +1 -0
- package/declarations/{callout.gts.d.ts → callout.d.ts} +1 -1
- package/declarations/callout.d.ts.map +1 -0
- package/declarations/{errors.gts.d.ts → errors.d.ts} +1 -1
- package/declarations/errors.d.ts.map +1 -0
- package/declarations/{h2.gts.d.ts → h2.d.ts} +1 -1
- package/declarations/h2.d.ts.map +1 -0
- package/declarations/{icons.gts.d.ts → icons.d.ts} +1 -1
- package/declarations/icons.d.ts.map +1 -0
- package/declarations/{index-page.gts.d.ts → index-page.d.ts} +2 -2
- package/declarations/index-page.d.ts.map +1 -0
- package/declarations/index.d.ts +12 -0
- package/declarations/index.d.ts.map +1 -0
- package/declarations/{links.gts.d.ts → links.d.ts} +1 -1
- package/declarations/links.d.ts.map +1 -0
- package/declarations/{menu-layout.gts.d.ts → menu-layout.d.ts} +1 -1
- package/declarations/menu-layout.d.ts.map +1 -0
- package/declarations/{page-layout.gts.d.ts → page-layout.d.ts} +1 -1
- package/declarations/page-layout.d.ts.map +1 -0
- package/declarations/{shell.gts.d.ts → shell.d.ts} +1 -1
- package/declarations/shell.d.ts.map +1 -0
- package/declarations/{side-nav.gts.d.ts → side-nav.d.ts} +2 -3
- package/declarations/side-nav.d.ts.map +1 -0
- package/declarations/{text.gts.d.ts → text.d.ts} +1 -1
- package/declarations/text.d.ts.map +1 -0
- package/declarations/{theme-toggle.gts.d.ts → theme-toggle.d.ts} +1 -1
- package/declarations/theme-toggle.d.ts.map +1 -0
- package/dist/icons.js +11 -11
- package/dist/icons.js.map +1 -1
- package/dist/index.js +340 -11
- package/dist/index.js.map +1 -1
- package/dist/site-css/featured-demo.css +2 -2
- package/package.json +33 -42
- package/{dist/article.js → src/article.gts} +6 -11
- package/src/callout.gts +18 -0
- package/src/errors.gts +19 -0
- package/src/h2.gts +5 -0
- package/src/icons.gts +150 -0
- package/src/index-page.css +22 -0
- package/src/index-page.gts +41 -0
- package/{declarations/index.gts.d.ts → src/index.gts} +6 -7
- package/src/links.gts +31 -0
- package/src/menu-layout.gts +43 -0
- package/src/page-layout.gts +137 -0
- package/src/shell.gts +37 -0
- package/src/side-nav.gts +190 -0
- package/src/site-css/components.css +23 -0
- package/src/site-css/featured-demo.css +9 -0
- package/src/site-css/shell.css +102 -0
- package/src/site-css/shiki.css +27 -0
- package/src/site-css/site.css +77 -0
- package/src/text.gts +5 -0
- package/src/theme-toggle.css +48 -0
- package/src/theme-toggle.gts +36 -0
- package/declarations/article.gts.d.ts.map +0 -1
- package/declarations/callout.gts.d.ts.map +0 -1
- package/declarations/errors.gts.d.ts.map +0 -1
- package/declarations/h2.gts.d.ts.map +0 -1
- package/declarations/icons.gts.d.ts.map +0 -1
- package/declarations/index-page.gts.d.ts.map +0 -1
- package/declarations/index.gts.d.ts.map +0 -1
- package/declarations/links.gts.d.ts.map +0 -1
- package/declarations/menu-layout.gts.d.ts.map +0 -1
- package/declarations/page-layout.gts.d.ts.map +0 -1
- package/declarations/shell.gts.d.ts.map +0 -1
- package/declarations/side-nav.gts.d.ts.map +0 -1
- package/declarations/text.gts.d.ts.map +0 -1
- package/declarations/theme-toggle.gts.d.ts.map +0 -1
- package/dist/article.js.map +0 -1
- package/dist/callout.js +0 -14
- package/dist/callout.js.map +0 -1
- package/dist/errors.js +0 -10
- package/dist/errors.js.map +0 -1
- package/dist/h2.js +0 -10
- package/dist/h2.js.map +0 -1
- package/dist/index-page.js +0 -15
- package/dist/index-page.js.map +0 -1
- package/dist/links.js +0 -30
- package/dist/links.js.map +0 -1
- package/dist/menu-layout.js +0 -26
- package/dist/menu-layout.js.map +0 -1
- package/dist/page-layout.js +0 -60
- package/dist/page-layout.js.map +0 -1
- package/dist/shell.js +0 -30
- package/dist/shell.js.map +0 -1
- package/dist/side-nav.js +0 -116
- package/dist/side-nav.js.map +0 -1
- package/dist/text.js +0 -10
- package/dist/text.js.map +0 -1
- package/dist/theme-toggle.js +0 -33
- package/dist/theme-toggle.js.map +0 -1
package/dist/side-nav.js
DELETED
|
@@ -1,116 +0,0 @@
|
|
|
1
|
-
import Component from '@glimmer/component';
|
|
2
|
-
import { on } from '@ember/modifier';
|
|
3
|
-
import { service } from '@ember/service';
|
|
4
|
-
import { sentenceCase } from 'change-case';
|
|
5
|
-
import { link } from 'ember-primitives/helpers';
|
|
6
|
-
import { PageNav } from 'kolay/components';
|
|
7
|
-
import { getAnchor } from 'should-handle-link';
|
|
8
|
-
import { precompileTemplate } from '@ember/template-compilation';
|
|
9
|
-
import { setComponentTemplate } from '@ember/component';
|
|
10
|
-
import templateOnly from '@ember/component/template-only';
|
|
11
|
-
import { g, i } from 'decorator-transforms/runtime';
|
|
12
|
-
|
|
13
|
-
function fixWords(text) {
|
|
14
|
-
switch (text.toLowerCase()) {
|
|
15
|
-
case 'ui':
|
|
16
|
-
return 'UI';
|
|
17
|
-
case 'iframe':
|
|
18
|
-
return 'IFrame';
|
|
19
|
-
default:
|
|
20
|
-
return text;
|
|
21
|
-
}
|
|
22
|
-
}
|
|
23
|
-
const joinUrl = (...strs) => {
|
|
24
|
-
let prefix = strs[0]?.startsWith('/') ? '/' : '';
|
|
25
|
-
return prefix + strs.map(s => s.replace(/^\//, '').replace(/\/$/, '')).filter(x => !!x).join('/');
|
|
26
|
-
};
|
|
27
|
-
/**
|
|
28
|
-
* Converts 1-2-hyphenated-thing
|
|
29
|
-
* to
|
|
30
|
-
* Hyphenated Thing
|
|
31
|
-
*/
|
|
32
|
-
const titleize = str => {
|
|
33
|
-
return str.split(/-|\s/).filter(Boolean).filter(text => !text.match(/^[\d]+$/)).map(text => `${text[0]?.toLocaleUpperCase()}${text.slice(1, text.length)}`).map(text => fixWords(text)).join(' ').split('.')[0] || '';
|
|
34
|
-
};
|
|
35
|
-
function nameFor(x) {
|
|
36
|
-
if ('componentName' in x) {
|
|
37
|
-
return `${x.componentName}`;
|
|
38
|
-
}
|
|
39
|
-
let page = x;
|
|
40
|
-
return page.title ? page.title : sentenceCase(page.name);
|
|
41
|
-
}
|
|
42
|
-
const asComponent = str => {
|
|
43
|
-
return `<${str.split('.')[0]?.replaceAll(' ', '')} />`;
|
|
44
|
-
};
|
|
45
|
-
const isComponents = str => str === 'components';
|
|
46
|
-
const SectionLink = setComponentTemplate(precompileTemplate("\n {{#let (link @href) as |l|}}\n <a href={{@href}} class=\"font-medium font-display\n {{if l.isActive \"text-sky-500\" \"text-slate-900 hover:text-slate-600 dark:text-white dark:hover:text-slate-300\"}}\" {{on \"click\" l.handleClick}} ...attributes>\n {{#if (isComponents @name)}}\n {{asComponent (titleize @name)}}\n {{else}}\n {{titleize @name}}\n {{/if}}\n </a>\n {{/let}}\n ", {
|
|
47
|
-
strictMode: true,
|
|
48
|
-
scope: () => ({
|
|
49
|
-
link,
|
|
50
|
-
on,
|
|
51
|
-
isComponents,
|
|
52
|
-
asComponent,
|
|
53
|
-
titleize
|
|
54
|
-
})
|
|
55
|
-
}), templateOnly());
|
|
56
|
-
const SubSectionLink = setComponentTemplate(precompileTemplate("\n {{#let (link @href) as |l|}}\n <a href={{@href}} class=\"block w-full before:pointer-events-none before:absolute before:-left-1 before:top-1/2 before:h-1.5 before:w-1.5 before:-translate-y-1/2 before:rounded-full\n {{if l.isActive \"font-semibold text-sky-500 before:bg-sky-500\" \"text-slate-500 before:hidden before:bg-slate-300 hover:text-slate-600 hover:before:block dark:text-slate-400 dark:before:bg-slate-700 dark:hover:text-slate-300\"}}\" {{on \"click\" l.handleClick}} ...attributes>\n {{#if (isComponents @name)}}\n {{asComponent (titleize @name)}}\n {{else}}\n {{titleize @name}}\n {{/if}}\n </a>\n {{/let}}\n ", {
|
|
57
|
-
strictMode: true,
|
|
58
|
-
scope: () => ({
|
|
59
|
-
link,
|
|
60
|
-
on,
|
|
61
|
-
isComponents,
|
|
62
|
-
asComponent,
|
|
63
|
-
titleize
|
|
64
|
-
})
|
|
65
|
-
}), templateOnly());
|
|
66
|
-
class SideNav extends Component {
|
|
67
|
-
static {
|
|
68
|
-
g(this.prototype, "docs", [service('kolay/docs')]);
|
|
69
|
-
}
|
|
70
|
-
#docs = (i(this, "docs"), void 0);
|
|
71
|
-
static {
|
|
72
|
-
g(this.prototype, "router", [service('router')]);
|
|
73
|
-
}
|
|
74
|
-
#router = (i(this, "router"), void 0);
|
|
75
|
-
get humanSelected() {
|
|
76
|
-
let path = this.docs.selected?.path;
|
|
77
|
-
if (!path) return undefined;
|
|
78
|
-
return path.split('/').filter(Boolean).map(titleize).join(' / ');
|
|
79
|
-
}
|
|
80
|
-
get rootUrl() {
|
|
81
|
-
return this.router.rootURL;
|
|
82
|
-
}
|
|
83
|
-
closeNav = event => {
|
|
84
|
-
if (!getAnchor(event)) return;
|
|
85
|
-
this.args.onClick?.();
|
|
86
|
-
};
|
|
87
|
-
/**
|
|
88
|
-
*
|
|
89
|
-
* This nav needs an aria-label to get around
|
|
90
|
-
* "Ensure landmarks are unique"
|
|
91
|
-
* because some demos render navs, and it's important that those
|
|
92
|
-
* demos are as simple as possible.
|
|
93
|
-
*
|
|
94
|
-
*
|
|
95
|
-
* nav isn't actually made in to an interactive element,
|
|
96
|
-
* it's an event delegation handler.
|
|
97
|
-
* The links themselves remain the actual interactive elements.
|
|
98
|
-
*/
|
|
99
|
-
static {
|
|
100
|
-
setComponentTemplate(precompileTemplate("\n <aside class=\"bg-white dark:bg-slate-900\" ...attributes>\n <PageNav aria-label=\"Main Navigation\">\n <:page as |x|>\n <SubSectionLink @href={{joinUrl this.rootUrl x.page.path}} @name={{nameFor x.page}} {{on \"click\" this.closeNav}} />\n </:page>\n\n <:collection as |x|>\n {{#if x.index}}\n <SectionLink @href={{joinUrl this.rootUrl x.index.page.path}} @name={{titleize x.collection.name}} {{on \"click\" this.closeNav}} />\n {{else}}\n <h2>\n {{titleize x.collection.name}}\n </h2>\n {{/if}}\n </:collection>\n </PageNav>\n </aside>\n ", {
|
|
101
|
-
strictMode: true,
|
|
102
|
-
scope: () => ({
|
|
103
|
-
PageNav,
|
|
104
|
-
SubSectionLink,
|
|
105
|
-
joinUrl,
|
|
106
|
-
nameFor,
|
|
107
|
-
on,
|
|
108
|
-
SectionLink,
|
|
109
|
-
titleize
|
|
110
|
-
})
|
|
111
|
-
}), this);
|
|
112
|
-
}
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
export { SideNav };
|
|
116
|
-
//# sourceMappingURL=side-nav.js.map
|
package/dist/side-nav.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"side-nav.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|
package/dist/text.js
DELETED
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import { precompileTemplate } from '@ember/template-compilation';
|
|
2
|
-
import { setComponentTemplate } from '@ember/component';
|
|
3
|
-
import templateOnly from '@ember/component/template-only';
|
|
4
|
-
|
|
5
|
-
const Text = setComponentTemplate(precompileTemplate("\n <span class=\"dark:text-white text:slate-900\">{{yield}}</span>\n", {
|
|
6
|
-
strictMode: true
|
|
7
|
-
}), templateOnly());
|
|
8
|
-
|
|
9
|
-
export { Text };
|
|
10
|
-
//# sourceMappingURL=text.js.map
|
package/dist/text.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"text.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;"}
|
package/dist/theme-toggle.js
DELETED
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
import './theme-toggle.css';
|
|
2
|
-
import { on } from '@ember/modifier';
|
|
3
|
-
import { Switch } from 'ember-primitives';
|
|
4
|
-
import { colorScheme } from 'ember-primitives/color-scheme';
|
|
5
|
-
import { Sun, Moon } from './icons.js';
|
|
6
|
-
import { precompileTemplate } from '@ember/template-compilation';
|
|
7
|
-
import { setComponentTemplate } from '@ember/component';
|
|
8
|
-
import templateOnly from '@ember/component/template-only';
|
|
9
|
-
|
|
10
|
-
function toggleTheme() {
|
|
11
|
-
if (colorScheme.current === 'dark') {
|
|
12
|
-
colorScheme.update('light');
|
|
13
|
-
} else {
|
|
14
|
-
colorScheme.update('dark');
|
|
15
|
-
}
|
|
16
|
-
}
|
|
17
|
-
function isDark() {
|
|
18
|
-
return colorScheme.current === 'dark';
|
|
19
|
-
}
|
|
20
|
-
const ThemeToggle = setComponentTemplate(precompileTemplate("\n <Switch class=\"site-theme-toggle\" as |s|>\n <s.Control name=\"color-scheme\" checked={{(isDark)}} {{on \"change\" toggleTheme}} />\n <s.Label>\n <span class=\"sr-only\">Toggle between light and dark mode</span>\n {{!--\n \uD83C\uDFB5 It's raining, it's pouring, ... \uD83C\uDFB5\n https://www.youtube.com/watch?v=ll5ykbAumD4\n --}}\n <Moon class=\"fill-sky-400\" />\n <Sun class=\"fill-yellow-400\" />\n <span class=\"ball\"></span>\n </s.Label>\n </Switch>\n", {
|
|
21
|
-
strictMode: true,
|
|
22
|
-
scope: () => ({
|
|
23
|
-
Switch,
|
|
24
|
-
isDark,
|
|
25
|
-
on,
|
|
26
|
-
toggleTheme,
|
|
27
|
-
Moon,
|
|
28
|
-
Sun
|
|
29
|
-
})
|
|
30
|
-
}), templateOnly());
|
|
31
|
-
|
|
32
|
-
export { ThemeToggle };
|
|
33
|
-
//# sourceMappingURL=theme-toggle.js.map
|
package/dist/theme-toggle.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"theme-toggle.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|