@operato/font 1.0.0-beta.9 → 1.0.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (46) hide show
  1. package/CHANGELOG.md +392 -0
  2. package/custom-elements.json +855 -0
  3. package/dist/src/font-creation-card.d.ts +18 -0
  4. package/dist/src/font-creation-card.js +258 -0
  5. package/dist/src/font-creation-card.js.map +1 -0
  6. package/dist/src/font-graphql-client.d.ts +20 -0
  7. package/dist/src/font-graphql-client.js +109 -0
  8. package/dist/src/font-graphql-client.js.map +1 -0
  9. package/dist/src/font-selector.d.ts +36 -0
  10. package/dist/src/font-selector.js +285 -0
  11. package/dist/src/font-selector.js.map +1 -0
  12. package/dist/src/index.d.ts +5 -0
  13. package/dist/src/index.js +6 -0
  14. package/dist/src/index.js.map +1 -0
  15. package/dist/src/ox-file-selector.d.ts +12 -0
  16. package/dist/src/ox-file-selector.js +129 -0
  17. package/dist/src/ox-file-selector.js.map +1 -0
  18. package/dist/src/ox-font-selector.d.ts +15 -0
  19. package/dist/src/ox-font-selector.js +88 -0
  20. package/dist/src/ox-font-selector.js.map +1 -0
  21. package/dist/src/ox-property-editor-font-selector.d.ts +8 -0
  22. package/dist/src/ox-property-editor-font-selector.js +13 -0
  23. package/dist/src/ox-property-editor-font-selector.js.map +1 -0
  24. package/dist/src/redux-font-actions.d.ts +7 -0
  25. package/dist/src/redux-font-actions.js +19 -0
  26. package/dist/src/redux-font-actions.js.map +1 -0
  27. package/dist/src/redux-font-reducers.d.ts +12 -0
  28. package/dist/src/redux-font-reducers.js +70 -0
  29. package/dist/src/redux-font-reducers.js.map +1 -0
  30. package/dist/tsconfig.tsbuildinfo +1 -0
  31. package/package.json +78 -20
  32. package/src/font-creation-card.ts +260 -0
  33. package/src/{graphql-client.js → font-graphql-client.ts} +35 -26
  34. package/src/font-selector.ts +284 -0
  35. package/src/index.ts +6 -0
  36. package/src/ox-file-selector.ts +114 -0
  37. package/src/ox-font-selector.ts +94 -0
  38. package/src/ox-property-editor-font-selector.ts +17 -0
  39. package/src/redux-font-actions.ts +21 -0
  40. package/src/redux-font-reducers.ts +88 -0
  41. package/src/font-creation-card.js +0 -311
  42. package/src/font-selector.js +0 -465
  43. package/src/index.js +0 -3
  44. package/src/ox-font-selector.js +0 -102
  45. package/src/ox-property-editor-font-selector.js +0 -25
  46. package/things-factory.config.js +0 -5
@@ -0,0 +1,18 @@
1
+ import './ox-file-selector';
2
+ import { LitElement } from 'lit';
3
+ declare const FontCreationCard_base: (new (...args: any[]) => LitElement) & typeof LitElement;
4
+ export declare class FontCreationCard extends FontCreationCard_base {
5
+ static styles: import("lit").CSSResult[];
6
+ provider: string;
7
+ googleFonts: Array<string>;
8
+ files?: Array<any>;
9
+ providers: Array<{
10
+ value: string;
11
+ display: string;
12
+ }>;
13
+ render(): import("lit-html").TemplateResult<1>;
14
+ onClickFlip(e: Event): void;
15
+ onClickSubmit(e: Event): Promise<void>;
16
+ reset(): void;
17
+ }
18
+ export {};
@@ -0,0 +1,258 @@
1
+ import { __decorate } from "tslib";
2
+ import './ox-file-selector';
3
+ import { LitElement, css, html } from 'lit';
4
+ import { customElement, property } from 'lit/decorators.js';
5
+ import { i18next, localize } from '@operato/i18n';
6
+ let FontCreationCard = class FontCreationCard extends localize(i18next)(LitElement) {
7
+ constructor() {
8
+ super(...arguments);
9
+ this.provider = 'google';
10
+ this.googleFonts = [];
11
+ this.providers = [
12
+ { value: 'google', display: 'Google' },
13
+ // TODO 구글 외 폰트 서비스 구현
14
+ // { value: 'typekit', display: 'Typekit' },
15
+ { value: 'custom', display: 'Custom' }
16
+ ];
17
+ }
18
+ render() {
19
+ let isProviderGoogle = this.provider == 'google' && this.googleFonts.length > 0;
20
+ let isFileAttached = this.files && this.files.length > 0 ? true : false;
21
+ return html `
22
+ <div @click=${(e) => this.onClickFlip(e)} front><mwc-icon>add_circle_outline</mwc-icon>create font</div>
23
+
24
+ <div @click=${(e) => this.onClickFlip(e)} back>
25
+ <form @submit=${(e) => this.onClickSubmit(e)}>
26
+ <div class="props">
27
+ <label>${i18next.t('label.provider')}</label>
28
+ <select
29
+ name="provider"
30
+ @change=${(e) => {
31
+ this.provider = e.target.value;
32
+ if (this.provider === 'google') {
33
+ fetch(`/all-google-fonts`).then(async (response) => {
34
+ if (response.ok)
35
+ this.googleFonts = await response.json();
36
+ else {
37
+ console.warn(`(${response.url}) ${response.status} ${response.statusText}. Could not load Google fonts.`);
38
+ }
39
+ });
40
+ }
41
+ }}
42
+ >
43
+ ${this.providers.map(p => html ` <option value=${p.value} ?selected=${this.provider == p.value}>${p.display}</option> `)}
44
+ </select>
45
+
46
+ <label>${i18next.t('label.name')}</label>
47
+ <input type="text" name="${isProviderGoogle ? '' : 'name'}" ?hidden=${isProviderGoogle} />
48
+ <select name="${isProviderGoogle ? 'name' : ''}" ?hidden=${!isProviderGoogle}>
49
+ <option value="">&nbsp;</option>
50
+ ${isProviderGoogle && this.googleFonts.map(f => html ` <option value=${f}>${f}</option> `)}
51
+ </select>
52
+
53
+ <label ?hidden=${this.provider != 'custom'}>${i18next.t('label.uri')}</label>
54
+ <input
55
+ ?hidden=${this.provider != 'custom'}
56
+ ?disabled=${isFileAttached}
57
+ .value=${isFileAttached ? this.files[0].name : ''}
58
+ type="text"
59
+ name="uri"
60
+ />
61
+ <!-- display when attachment module is imported -->
62
+ <label ?hidden=${this.provider != 'custom'}>${i18next.t('label.file')}</label>
63
+ <ox-file-selector
64
+ class="${this.provider != 'custom' ? 'hidden' : ''}"
65
+ name="file"
66
+ label="${i18next.t('label.select file')}"
67
+ accept=".ttf,.otf,.woff,.woff2,.eot,.svg,.svgz"
68
+ multiple
69
+ @file-change=${(e) => {
70
+ this.files = Array.from(e.detail.files);
71
+ }}
72
+ ></ox-file-selector>
73
+ <!------------------------------------------------>
74
+
75
+ <label for="checkbox-active" @click=${(e) => e.stopPropagation()}>
76
+ ${i18next.t('label.active')}
77
+ </label>
78
+ <input id="checkbox-active" type="checkbox" name="active" checked />
79
+ </div>
80
+ <div></div>
81
+ <input type="submit" value=${i18next.t('button.create')} />
82
+ </form>
83
+ </div>
84
+ `;
85
+ }
86
+ onClickFlip(e) {
87
+ const target = e.target;
88
+ const currentTarget = e.currentTarget;
89
+ if (!['INPUT', 'SELECT', 'OPTION'].find(tagName => tagName === target.tagName)) {
90
+ if (currentTarget.hasAttribute('front'))
91
+ this.reset(); // 입력 폼으로 뒤집기 전에 한 번 리셋
92
+ this.classList.toggle('flipped');
93
+ }
94
+ }
95
+ async onClickSubmit(e) {
96
+ e.preventDefault();
97
+ e.stopPropagation();
98
+ var form = e.target;
99
+ var detail = {};
100
+ detail.name = form.elements.namedItem('name').value;
101
+ detail.provider = form.elements.namedItem('provider').value;
102
+ detail.active = form.elements.namedItem('active').checked;
103
+ if (this.provider === 'custom') {
104
+ detail.uri = form.elements.namedItem('uri').value;
105
+ if (this.files && this.files.length > 0) {
106
+ detail.files = this.files;
107
+ }
108
+ }
109
+ this.dispatchEvent(new CustomEvent('create-font', { detail }));
110
+ }
111
+ reset() {
112
+ var form = this.renderRoot.querySelector('form');
113
+ if (form) {
114
+ form.reset();
115
+ }
116
+ this.files = [];
117
+ this.classList.remove('flipped');
118
+ }
119
+ };
120
+ FontCreationCard.styles = [
121
+ css `
122
+ :host {
123
+ position: relative;
124
+
125
+ padding: 0;
126
+ margin: 0;
127
+ height: 100%;
128
+
129
+ -webkit-transform-style: preserve-3d;
130
+ transform-style: preserve-3d;
131
+ -webkit-transition: all 0.5s ease-in-out;
132
+ transition: all 0.5s ease-in-out;
133
+ }
134
+
135
+ :host(.flipped) {
136
+ -webkit-transform: var(--card-list-flip-transform);
137
+ transform: var(--card-list-flip-transform);
138
+ }
139
+
140
+ [front],
141
+ [back] {
142
+ position: absolute;
143
+
144
+ width: 100%;
145
+ height: 100%;
146
+ margin: 0;
147
+ padding: 0;
148
+
149
+ border: var(--card-list-create-border);
150
+ border-radius: var(--card-list-create-border-radius);
151
+
152
+ background-color: #fff;
153
+
154
+ -webkit-backface-visibility: hidden;
155
+ backface-visibility: hidden;
156
+ }
157
+
158
+ [front] {
159
+ display: flex;
160
+ flex-direction: column;
161
+ align-items: center;
162
+ justify-content: center;
163
+
164
+ text-align: center;
165
+ font-size: 0.8em;
166
+ color: var(--card-list-create-color);
167
+ text-transform: capitalize;
168
+ }
169
+
170
+ [front] mwc-icon {
171
+ font-size: 3.5em;
172
+ color: var(--card-list-create-icon-color);
173
+ }
174
+
175
+ [back] {
176
+ -webkit-transform: var(--card-list-flip-transform);
177
+ transform: var(--card-list-flip-transform);
178
+ box-sizing: border-box;
179
+ display: grid;
180
+ }
181
+
182
+ [back] form {
183
+ padding: var(--card-list-create-form-padding);
184
+ width: 100%;
185
+ height: 100%;
186
+ box-sizing: border-box;
187
+ display: grid;
188
+ grid-template-columns: 1fr;
189
+ grid-template-rows: auto 1fr auto;
190
+ justify-content: center;
191
+ align-items: center;
192
+ }
193
+
194
+ [back] form .props {
195
+ width: 100%;
196
+ height: 100%;
197
+ box-sizing: border-box;
198
+ display: grid;
199
+ grid-template-columns: repeat(10, 1fr);
200
+ grid-row-gap: 7px;
201
+ justify-content: center;
202
+ align-items: center;
203
+ }
204
+
205
+ [back] form .props label {
206
+ grid-column: span 4;
207
+ font: var(--card-list-create-label-font);
208
+ color: var(--card-list-create-label-color);
209
+ }
210
+
211
+ [back] form .props input,
212
+ [back] form .props select {
213
+ grid-column: span 6;
214
+ background-color: #fff;
215
+ border: var(--card-list-create-input-border);
216
+ border-radius: var(--card-list-create-input-border-radius);
217
+ font: var(--card-list-create-input-font);
218
+ color: var(--card-list-create-input-color);
219
+ width: -moz-available;
220
+ }
221
+
222
+ ox-file-selector {
223
+ grid-column: span 6;
224
+ font: var(--card-list-create-input-font);
225
+ border: none;
226
+ box-sizing: border-box;
227
+ padding: 0;
228
+ }
229
+
230
+ [back] input[type='submit'] {
231
+ background-color: var(--button-background-color) !important;
232
+ font: var(--button-font);
233
+ color: var(--button-color) !important;
234
+ border-radius: var(--button-radius);
235
+ border: var(--button-border);
236
+ grid-column: span 10;
237
+ grid-row: auto / -1;
238
+ }
239
+
240
+ .hidden {
241
+ display: none !important;
242
+ }
243
+ `
244
+ ];
245
+ __decorate([
246
+ property({ type: String })
247
+ ], FontCreationCard.prototype, "provider", void 0);
248
+ __decorate([
249
+ property({ type: Array })
250
+ ], FontCreationCard.prototype, "googleFonts", void 0);
251
+ __decorate([
252
+ property({ type: Array })
253
+ ], FontCreationCard.prototype, "files", void 0);
254
+ FontCreationCard = __decorate([
255
+ customElement('font-creation-card')
256
+ ], FontCreationCard);
257
+ export { FontCreationCard };
258
+ //# sourceMappingURL=font-creation-card.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"font-creation-card.js","sourceRoot":"","sources":["../../src/font-creation-card.ts"],"names":[],"mappings":"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","sourcesContent":["import './ox-file-selector'\n\nimport { LitElement, css, html } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\nimport { i18next, localize } from '@operato/i18n'\n\n@customElement('font-creation-card')\nexport class FontCreationCard extends localize(i18next)(LitElement) {\n static styles = [\n css`\n :host {\n position: relative;\n\n padding: 0;\n margin: 0;\n height: 100%;\n\n -webkit-transform-style: preserve-3d;\n transform-style: preserve-3d;\n -webkit-transition: all 0.5s ease-in-out;\n transition: all 0.5s ease-in-out;\n }\n\n :host(.flipped) {\n -webkit-transform: var(--card-list-flip-transform);\n transform: var(--card-list-flip-transform);\n }\n\n [front],\n [back] {\n position: absolute;\n\n width: 100%;\n height: 100%;\n margin: 0;\n padding: 0;\n\n border: var(--card-list-create-border);\n border-radius: var(--card-list-create-border-radius);\n\n background-color: #fff;\n\n -webkit-backface-visibility: hidden;\n backface-visibility: hidden;\n }\n\n [front] {\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n\n text-align: center;\n font-size: 0.8em;\n color: var(--card-list-create-color);\n text-transform: capitalize;\n }\n\n [front] mwc-icon {\n font-size: 3.5em;\n color: var(--card-list-create-icon-color);\n }\n\n [back] {\n -webkit-transform: var(--card-list-flip-transform);\n transform: var(--card-list-flip-transform);\n box-sizing: border-box;\n display: grid;\n }\n\n [back] form {\n padding: var(--card-list-create-form-padding);\n width: 100%;\n height: 100%;\n box-sizing: border-box;\n display: grid;\n grid-template-columns: 1fr;\n grid-template-rows: auto 1fr auto;\n justify-content: center;\n align-items: center;\n }\n\n [back] form .props {\n width: 100%;\n height: 100%;\n box-sizing: border-box;\n display: grid;\n grid-template-columns: repeat(10, 1fr);\n grid-row-gap: 7px;\n justify-content: center;\n align-items: center;\n }\n\n [back] form .props label {\n grid-column: span 4;\n font: var(--card-list-create-label-font);\n color: var(--card-list-create-label-color);\n }\n\n [back] form .props input,\n [back] form .props select {\n grid-column: span 6;\n background-color: #fff;\n border: var(--card-list-create-input-border);\n border-radius: var(--card-list-create-input-border-radius);\n font: var(--card-list-create-input-font);\n color: var(--card-list-create-input-color);\n width: -moz-available;\n }\n\n ox-file-selector {\n grid-column: span 6;\n font: var(--card-list-create-input-font);\n border: none;\n box-sizing: border-box;\n padding: 0;\n }\n\n [back] input[type='submit'] {\n background-color: var(--button-background-color) !important;\n font: var(--button-font);\n color: var(--button-color) !important;\n border-radius: var(--button-radius);\n border: var(--button-border);\n grid-column: span 10;\n grid-row: auto / -1;\n }\n\n .hidden {\n display: none !important;\n }\n `\n ]\n\n @property({ type: String }) provider: string = 'google'\n @property({ type: Array }) googleFonts: Array<string> = []\n @property({ type: Array }) files?: Array<any>\n\n providers: Array<{ value: string; display: string }> = [\n { value: 'google', display: 'Google' },\n // TODO 구글 외 폰트 서비스 구현\n // { value: 'typekit', display: 'Typekit' },\n { value: 'custom', display: 'Custom' }\n ]\n\n render() {\n let isProviderGoogle = this.provider == 'google' && this.googleFonts.length > 0\n let isFileAttached = this.files && this.files.length > 0 ? true : false\n\n return html`\n <div @click=${(e: Event) => this.onClickFlip(e)} front><mwc-icon>add_circle_outline</mwc-icon>create font</div>\n\n <div @click=${(e: Event) => this.onClickFlip(e)} back>\n <form @submit=${(e: Event) => this.onClickSubmit(e)}>\n <div class=\"props\">\n <label>${i18next.t('label.provider')}</label>\n <select\n name=\"provider\"\n @change=${(e: Event) => {\n this.provider = (e.target as HTMLInputElement).value\n if (this.provider === 'google') {\n fetch(`/all-google-fonts`).then(async response => {\n if (response.ok) this.googleFonts = await response.json()\n else {\n console.warn(\n `(${response.url}) ${response.status} ${response.statusText}. Could not load Google fonts.`\n )\n }\n })\n }\n }}\n >\n ${this.providers.map(\n p => html` <option value=${p.value} ?selected=${this.provider == p.value}>${p.display}</option> `\n )}\n </select>\n\n <label>${i18next.t('label.name')}</label>\n <input type=\"text\" name=\"${isProviderGoogle ? '' : 'name'}\" ?hidden=${isProviderGoogle} />\n <select name=\"${isProviderGoogle ? 'name' : ''}\" ?hidden=${!isProviderGoogle}>\n <option value=\"\">&nbsp;</option>\n ${isProviderGoogle && this.googleFonts.map(f => html` <option value=${f}>${f}</option> `)}\n </select>\n\n <label ?hidden=${this.provider != 'custom'}>${i18next.t('label.uri')}</label>\n <input\n ?hidden=${this.provider != 'custom'}\n ?disabled=${isFileAttached}\n .value=${isFileAttached ? this.files![0].name : ''}\n type=\"text\"\n name=\"uri\"\n />\n <!-- display when attachment module is imported -->\n <label ?hidden=${this.provider != 'custom'}>${i18next.t('label.file')}</label>\n <ox-file-selector\n class=\"${this.provider != 'custom' ? 'hidden' : ''}\"\n name=\"file\"\n label=\"${i18next.t('label.select file')}\"\n accept=\".ttf,.otf,.woff,.woff2,.eot,.svg,.svgz\"\n multiple\n @file-change=${(e: CustomEvent) => {\n this.files = Array.from(e.detail.files)\n }}\n ></ox-file-selector>\n <!------------------------------------------------>\n\n <label for=\"checkbox-active\" @click=${(e: Event) => e.stopPropagation()}>\n ${i18next.t('label.active')}\n </label>\n <input id=\"checkbox-active\" type=\"checkbox\" name=\"active\" checked />\n </div>\n <div></div>\n <input type=\"submit\" value=${i18next.t('button.create')} />\n </form>\n </div>\n `\n }\n\n onClickFlip(e: Event) {\n const target = e.target as HTMLElement\n const currentTarget = e.currentTarget as HTMLElement\n\n if (!['INPUT', 'SELECT', 'OPTION'].find(tagName => tagName === target.tagName)) {\n if (currentTarget.hasAttribute('front')) this.reset() // 입력 폼으로 뒤집기 전에 한 번 리셋\n this.classList.toggle('flipped')\n }\n }\n\n async onClickSubmit(e: Event) {\n e.preventDefault()\n e.stopPropagation()\n\n var form = e.target as HTMLFormElement\n\n var detail = {} as any\n\n detail.name = (form.elements.namedItem('name') as HTMLInputElement).value\n detail.provider = (form.elements.namedItem('provider') as HTMLInputElement).value\n detail.active = (form.elements.namedItem('active') as HTMLInputElement).checked\n\n if (this.provider === 'custom') {\n detail.uri = (form.elements.namedItem('uri') as HTMLInputElement).value\n if (this.files && this.files.length > 0) {\n detail.files = this.files\n }\n }\n\n this.dispatchEvent(new CustomEvent('create-font', { detail }))\n }\n\n reset() {\n var form = this.renderRoot.querySelector('form')\n if (form) {\n form.reset()\n }\n\n this.files = []\n this.classList.remove('flipped')\n }\n}\n"]}
@@ -0,0 +1,20 @@
1
+ /**
2
+ * @param {Object} listParam {filters, pagination, sortings}
3
+ */
4
+ export declare function fetchFontList(listParam?: {
5
+ sortings?: any;
6
+ filters?: any;
7
+ pagination?: any;
8
+ }): Promise<any>;
9
+ /**
10
+ * @param {Object} font Font patch
11
+ */
12
+ export declare function createFont(font: any): Promise<any>;
13
+ /**
14
+ * @param {Object} font Font patch
15
+ */
16
+ export declare function updateFont(font: any): Promise<any>;
17
+ /**
18
+ * @param {String} id Font id
19
+ */
20
+ export declare function deleteFont(id: string): Promise<any>;
@@ -0,0 +1,109 @@
1
+ import { client } from '@operato/graphql';
2
+ import gql from 'graphql-tag';
3
+ /**
4
+ * @param {Object} listParam {filters, pagination, sortings}
5
+ */
6
+ export async function fetchFontList(listParam) {
7
+ const response = await client.query({
8
+ query: gql `
9
+ query ($filters: [Filter!], $pagination: Pagination, $sortings: [Sorting!]) {
10
+ fonts(filters: $filters, pagination: $pagination, sortings: $sortings) {
11
+ items {
12
+ id
13
+ name
14
+ provider
15
+ uri
16
+ path
17
+ active
18
+ files {
19
+ name
20
+ fullpath
21
+ }
22
+ createdAt
23
+ updatedAt
24
+ }
25
+ total
26
+ }
27
+ }
28
+ `,
29
+ variables: listParam
30
+ });
31
+ return response.data && response.data.fonts;
32
+ }
33
+ /**
34
+ * @param {Object} font Font patch
35
+ */
36
+ export async function createFont(font) {
37
+ const response = await client.mutate({
38
+ mutation: gql `
39
+ mutation CreateFont($font: NewFont!) {
40
+ createFont(font: $font) {
41
+ name
42
+ provider
43
+ uri
44
+ path
45
+ active
46
+ createdAt
47
+ updatedAt
48
+ }
49
+ }
50
+ `,
51
+ variables: {
52
+ font: { active: false, ...font }
53
+ },
54
+ context: {
55
+ hasUpload: true
56
+ }
57
+ });
58
+ return response.data;
59
+ }
60
+ /**
61
+ * @param {Object} font Font patch
62
+ */
63
+ export async function updateFont(font) {
64
+ var { id, ...patch } = font;
65
+ const response = await client.mutate({
66
+ mutation: gql `
67
+ mutation UpdateFont($id: String!, $patch: FontPatch!) {
68
+ updateFont(id: $id, patch: $patch) {
69
+ id
70
+ name
71
+ provider
72
+ files {
73
+ name
74
+ fullpath
75
+ }
76
+ path
77
+ active
78
+ createdAt
79
+ updatedAt
80
+ }
81
+ }
82
+ `,
83
+ variables: {
84
+ id,
85
+ patch
86
+ },
87
+ context: {
88
+ hasUpload: true
89
+ }
90
+ });
91
+ return response.data;
92
+ }
93
+ /**
94
+ * @param {String} id Font id
95
+ */
96
+ export async function deleteFont(id) {
97
+ const response = await client.mutate({
98
+ mutation: gql `
99
+ mutation ($id: String!) {
100
+ deleteFont(id: $id)
101
+ }
102
+ `,
103
+ variables: {
104
+ id
105
+ }
106
+ });
107
+ return response.data;
108
+ }
109
+ //# sourceMappingURL=font-graphql-client.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"font-graphql-client.js","sourceRoot":"","sources":["../../src/font-graphql-client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAA;AACzC,OAAO,GAAG,MAAM,aAAa,CAAA;AAE7B;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,aAAa,CAAC,SAA+D;IACjG,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,KAAK,CAAC;QAClC,KAAK,EAAE,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;KAoBT;QACD,SAAS,EAAE,SAAS;KACrB,CAAC,CAAA;IAEF,OAAO,QAAQ,CAAC,IAAI,IAAI,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAA;AAC7C,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,UAAU,CAAC,IAAS;IACxC,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,MAAM,CAAC;QACnC,QAAQ,EAAE,GAAG,CAAA;;;;;;;;;;;;KAYZ;QACD,SAAS,EAAE;YACT,IAAI,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,IAAI,EAAE;SACjC;QACD,OAAO,EAAE;YACP,SAAS,EAAE,IAAI;SAChB;KACF,CAAC,CAAA;IAEF,OAAO,QAAQ,CAAC,IAAI,CAAA;AACtB,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,UAAU,CAAC,IAAS;IACxC,IAAI,EAAE,EAAE,EAAE,GAAG,KAAK,EAAE,GAAG,IAAI,CAAA;IAE3B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,MAAM,CAAC;QACnC,QAAQ,EAAE,GAAG,CAAA;;;;;;;;;;;;;;;;KAgBZ;QACD,SAAS,EAAE;YACT,EAAE;YACF,KAAK;SACN;QACD,OAAO,EAAE;YACP,SAAS,EAAE,IAAI;SAChB;KACF,CAAC,CAAA;IAEF,OAAO,QAAQ,CAAC,IAAI,CAAA;AACtB,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,UAAU,CAAC,EAAU;IACzC,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,MAAM,CAAC;QACnC,QAAQ,EAAE,GAAG,CAAA;;;;KAIZ;QACD,SAAS,EAAE;YACT,EAAE;SACH;KACF,CAAC,CAAA;IAEF,OAAO,QAAQ,CAAC,IAAI,CAAA;AACtB,CAAC","sourcesContent":["import { client } from '@operato/graphql'\nimport gql from 'graphql-tag'\n\n/**\n * @param {Object} listParam {filters, pagination, sortings}\n */\nexport async function fetchFontList(listParam?: { sortings?: any; filters?: any; pagination?: any }) {\n const response = await client.query({\n query: gql`\n query ($filters: [Filter!], $pagination: Pagination, $sortings: [Sorting!]) {\n fonts(filters: $filters, pagination: $pagination, sortings: $sortings) {\n items {\n id\n name\n provider\n uri\n path\n active\n files {\n name\n fullpath\n }\n createdAt\n updatedAt\n }\n total\n }\n }\n `,\n variables: listParam\n })\n\n return response.data && response.data.fonts\n}\n\n/**\n * @param {Object} font Font patch\n */\nexport async function createFont(font: any) {\n const response = await client.mutate({\n mutation: gql`\n mutation CreateFont($font: NewFont!) {\n createFont(font: $font) {\n name\n provider\n uri\n path\n active\n createdAt\n updatedAt\n }\n }\n `,\n variables: {\n font: { active: false, ...font }\n },\n context: {\n hasUpload: true\n }\n })\n\n return response.data\n}\n\n/**\n * @param {Object} font Font patch\n */\nexport async function updateFont(font: any) {\n var { id, ...patch } = font\n\n const response = await client.mutate({\n mutation: gql`\n mutation UpdateFont($id: String!, $patch: FontPatch!) {\n updateFont(id: $id, patch: $patch) {\n id\n name\n provider\n files {\n name\n fullpath\n }\n path\n active\n createdAt\n updatedAt\n }\n }\n `,\n variables: {\n id,\n patch\n },\n context: {\n hasUpload: true\n }\n })\n\n return response.data\n}\n\n/**\n * @param {String} id Font id\n */\nexport async function deleteFont(id: string) {\n const response = await client.mutate({\n mutation: gql`\n mutation ($id: String!) {\n deleteFont(id: $id)\n }\n `,\n variables: {\n id\n }\n })\n\n return response.data\n}\n"]}
@@ -0,0 +1,36 @@
1
+ import './font-creation-card';
2
+ import { LitElement, PropertyValues } from 'lit';
3
+ declare const FontSelector_base: (new (...args: any[]) => LitElement) & (new (...args: any[]) => {
4
+ _storeUnsubscribe: import("redux").Unsubscribe;
5
+ connectedCallback(): void;
6
+ disconnectedCallback(): void;
7
+ stateChanged(_state: unknown): void;
8
+ readonly isConnected: boolean;
9
+ }) & typeof LitElement;
10
+ export declare class FontSelector extends FontSelector_base {
11
+ static styles: import("lit").CSSResult[];
12
+ fonts: Array<any>;
13
+ creatable: boolean;
14
+ provider: string;
15
+ main: HTMLElement;
16
+ filter: HTMLElement;
17
+ creationCard: {
18
+ reset: () => {};
19
+ };
20
+ showGotoTop: boolean;
21
+ render(): import("lit-html").TemplateResult<1>;
22
+ firstUpdated(): Promise<void>;
23
+ stateChanged(state: any): void;
24
+ updated(changes: PropertyValues<this>): void;
25
+ refresh(): Promise<any>;
26
+ toggleActive(font: {
27
+ id: string;
28
+ active: boolean;
29
+ }): Promise<void>;
30
+ onCreateFont(e: CustomEvent): Promise<void>;
31
+ deleteFont(font: {
32
+ id: string;
33
+ }): Promise<void>;
34
+ onClickSelect(font: any): void;
35
+ }
36
+ export {};