doclific 0.2.9 → 0.3.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/dist/bin/doclific.js +50 -1
- package/dist/core/ai.js +140 -0
- package/dist/core/codebase.js +49 -3
- package/dist/public/assets/Preview-CfLVfmH2.js +1 -0
- package/dist/public/assets/ar-SA-G6X2FPQ2-zGa4nmKj.js +10 -0
- package/dist/public/assets/arc-DPZnwcfX.js +1 -0
- package/dist/public/assets/az-AZ-76LH7QW2-2ofaYqg_.js +1 -0
- package/dist/public/assets/bg-BG-XCXSNQG7-djDKLEln.js +5 -0
- package/dist/public/assets/blockDiagram-38ab4fdb-CkyydZLe.js +118 -0
- package/dist/public/assets/bn-BD-2XOGV67Q-DHBogyv-.js +5 -0
- package/dist/public/assets/c4Diagram-3d4e48cf-R8x2FAAi.js +10 -0
- package/dist/public/assets/ca-ES-6MX7JW3Y-OWWCWvuP.js +8 -0
- package/dist/public/assets/channel-BE2ulzlx.js +1 -0
- package/dist/public/assets/classDiagram-70f12bd4-BP-7G8u1.js +2 -0
- package/dist/public/assets/classDiagram-v2-f2320105-k8KFvaSn.js +2 -0
- package/dist/public/assets/clone-axZLZjOa.js +1 -0
- package/dist/public/assets/createText-2e5e7dd3-Cbi8xL03.js +7 -0
- package/dist/public/assets/cs-CZ-2BRQDIVT-CP9xiC8w.js +11 -0
- package/dist/public/assets/da-DK-5WZEPLOC-Cpbm5Bju.js +5 -0
- package/dist/public/assets/de-DE-XR44H4JA-D8rOmKQW.js +8 -0
- package/dist/public/assets/edges-e0da2a9e-Cv6SpBo3.js +4 -0
- package/dist/public/assets/el-GR-BZB4AONW-BgQNs1cl.js +10 -0
- package/dist/public/assets/erDiagram-9861fffd-CLds4aY4.js +51 -0
- package/dist/public/assets/es-ES-U4NZUMDT-C1M-3kUi.js +9 -0
- package/dist/public/assets/eu-ES-A7QVB2H4-sIoA4F86.js +11 -0
- package/dist/public/assets/fa-IR-HGAKTJCU-CtmSfjBe.js +8 -0
- package/dist/public/assets/fi-FI-Z5N7JZ37-CkqAf83a.js +6 -0
- package/dist/public/assets/flowDb-956e92f1-VASBzIvX.js +10 -0
- package/dist/public/assets/flowDiagram-66a62f08-00amExuc.js +4 -0
- package/dist/public/assets/flowDiagram-v2-96b9c2cf-DvEC9OW-.js +1 -0
- package/dist/public/assets/flowchart-elk-definition-4a651766-DuK0a8x4.js +139 -0
- package/dist/public/assets/fr-FR-RHASNOE6-BLTlR38v.js +9 -0
- package/dist/public/assets/ganttDiagram-c361ad54-Bfv8sOWo.js +257 -0
- package/dist/public/assets/gitGraphDiagram-72cf32ee-CJcs55Tw.js +70 -0
- package/dist/public/assets/gl-ES-HMX3MZ6V-DiriMGaf.js +10 -0
- package/dist/public/assets/graph-CzpZTUYm.js +1 -0
- package/dist/public/assets/he-IL-6SHJWFNN-BGgOoPZG.js +10 -0
- package/dist/public/assets/hi-IN-IWLTKZ5I-C4QTfw3M.js +4 -0
- package/dist/public/assets/hu-HU-A5ZG7DT2-DGtzDRRU.js +7 -0
- package/dist/public/assets/id-ID-SAP4L64H-CzcaN-wr.js +10 -0
- package/dist/public/assets/index-3862675e-BHyuTWf3.js +1 -0
- package/dist/public/assets/index-Bu97Fipb.js +95 -0
- package/dist/public/assets/index-CbwMLPrZ.css +1 -0
- package/dist/public/assets/index-Cr2gUYn7.js +613 -0
- package/dist/public/assets/index-rmPcGL9S.js +3299 -0
- package/dist/public/assets/infoDiagram-f8f76790-Bzs_oiEq.js +7 -0
- package/dist/public/assets/it-IT-JPQ66NNP-DEqzEHhG.js +11 -0
- package/dist/public/assets/ja-JP-DBVTYXUO-DQOZh6jj.js +8 -0
- package/dist/public/assets/journeyDiagram-49397b02-hbhF2GTs.js +139 -0
- package/dist/public/assets/kaa-6HZHGXH3-DAsn8pMz.js +1 -0
- package/dist/public/assets/kab-KAB-ZGHBKWFO-hbSn2yHo.js +8 -0
- package/dist/public/assets/kk-KZ-P5N5QNE5-DJbDGpSa.js +1 -0
- package/dist/public/assets/km-KH-HSX4SM5Z-CF1cSYpx.js +11 -0
- package/dist/public/assets/ko-KR-MTYHY66A-D0j8sNVo.js +9 -0
- package/dist/public/assets/ku-TR-6OUDTVRD-DZ47lKMP.js +9 -0
- package/dist/public/assets/layout-Ch5pbbc5.js +1 -0
- package/dist/public/assets/line-BEMT2b8O.js +1 -0
- package/dist/public/assets/linear-DrlVBQ0m.js +1 -0
- package/dist/public/assets/lt-LT-XHIRWOB4-B_rQQq9i.js +3 -0
- package/dist/public/assets/lv-LV-5QDEKY6T-CLpzoE_t.js +7 -0
- package/dist/public/assets/mindmap-definition-fc14e90a-4BkML5nr.js +415 -0
- package/dist/public/assets/mr-IN-CRQNXWMA-BUEgszaQ.js +13 -0
- package/dist/public/assets/my-MM-5M5IBNSE-Dn6dj_g-.js +1 -0
- package/dist/public/assets/nb-NO-T6EIAALU-CDRfxO5D.js +10 -0
- package/dist/public/assets/nl-NL-IS3SIHDZ-C7BWZ57w.js +8 -0
- package/dist/public/assets/nn-NO-6E72VCQL-DgWcUCmS.js +8 -0
- package/dist/public/assets/oc-FR-POXYY2M6-C64no2Sz.js +8 -0
- package/dist/public/assets/pa-IN-N4M65BXN-CdXAiUa-.js +4 -0
- package/dist/public/assets/percentages-BXMCSKIN-DmjnxD3b.js +159 -0
- package/dist/public/assets/pica-UyEFQr7o.js +2 -0
- package/dist/public/assets/pieDiagram-8a3498a8-BnZKl0HM.js +35 -0
- package/dist/public/assets/pl-PL-T2D74RX3-BfktR2GC.js +9 -0
- package/dist/public/assets/pt-BR-5N22H2LF-BMS0hGhj.js +9 -0
- package/dist/public/assets/pt-PT-UZXXM6DQ-Clt_m-aW.js +9 -0
- package/dist/public/assets/quadrantDiagram-120e2f19-Cle8VMl3.js +7 -0
- package/dist/public/assets/react-AWXP2p19.js +6 -0
- package/dist/public/assets/react-BY3n_q7a.js +19 -0
- package/dist/public/assets/react-BZVgOt_z.js +22 -0
- package/dist/public/assets/react-BxN1Fkhi.js +34 -0
- package/dist/public/assets/react-DBLYdRms.js +21 -0
- package/dist/public/assets/react-DGFZQemO.js +1 -0
- package/dist/public/assets/react-DMuqKR18.js +17 -0
- package/dist/public/assets/react-Ds4RMtsz.js +19 -0
- package/dist/public/assets/requirementDiagram-deff3bca-CYs2kOsx.js +52 -0
- package/dist/public/assets/ro-RO-JPDTUUEW-8VZwJRTB.js +11 -0
- package/dist/public/assets/ru-RU-B4JR7IUQ-DXB6WjCJ.js +9 -0
- package/dist/public/assets/sankeyDiagram-04a897e0-CjgF0ShR.js +8 -0
- package/dist/public/assets/sequenceDiagram-704730f1-YZDjgz23.js +122 -0
- package/dist/public/assets/si-LK-N5RQ5JYF-3OCpve4d.js +1 -0
- package/dist/public/assets/sk-SK-C5VTKIMK-BEWKAYUl.js +6 -0
- package/dist/public/assets/sl-SI-NN7IZMDC-CjuniHw8.js +6 -0
- package/dist/public/assets/stateDiagram-587899a1-BYww5TLf.js +1 -0
- package/dist/public/assets/stateDiagram-v2-d93cdb3a-_alqERD3.js +1 -0
- package/dist/public/assets/styles-6aaf32cf-D-L1HpzD.js +207 -0
- package/dist/public/assets/styles-9a916d00-CEw3szBU.js +160 -0
- package/dist/public/assets/styles-c10674c1-PtYrOZV8.js +116 -0
- package/dist/public/assets/subset-shared.chunk-BwUUnLRt.js +22 -0
- package/dist/public/assets/subset-worker.chunk-CHKbzn25.js +1 -0
- package/dist/public/assets/sv-SE-XGPEYMSR-C02T2BPU.js +10 -0
- package/dist/public/assets/svgDrawCommon-08f97a94-CEqvQOUt.js +1 -0
- package/dist/public/assets/ta-IN-2NMHFXQM-Dwu_LpR7.js +9 -0
- package/dist/public/assets/th-TH-HPSO5L25-BAmgMbAJ.js +2 -0
- package/dist/public/assets/timeline-definition-85554ec2-CFt0t_Cz.js +61 -0
- package/dist/public/assets/tr-TR-DEFEU3FU-vTO9xmBO.js +7 -0
- package/dist/public/assets/uk-UA-QMV73CPH-yUd9Af6s.js +6 -0
- package/dist/public/assets/vi-VN-M7AON7JQ-Cy6tHM0s.js +5 -0
- package/dist/public/assets/xychartDiagram-e933f94c-3I_ghsu8.js +7 -0
- package/dist/public/assets/zh-CN-LNUGB5OW-BKmxs4M8.js +10 -0
- package/dist/public/assets/zh-HK-E62DVLB3-B7dqTsZx.js +1 -0
- package/dist/public/assets/zh-TW-RAJ6MFWO-C9A8RaNK.js +9 -0
- package/dist/public/index.html +3 -3
- package/dist/server/index.js +1 -1
- package/dist/server/router.js +9 -0
- package/package.json +7 -1
package/dist/bin/doclific.js
CHANGED
|
@@ -1,11 +1,26 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
2
|
import { startServer } from '../server/index.js';
|
|
3
|
-
import { mkdir } from 'fs/promises';
|
|
3
|
+
import { mkdir, readFile, writeFile } from 'fs/promises';
|
|
4
4
|
import { existsSync } from 'fs';
|
|
5
5
|
import path from 'path';
|
|
6
6
|
import open from 'open';
|
|
7
|
+
import os from 'os';
|
|
8
|
+
const CONFIG_DIR = path.join(os.homedir(), '.config', 'doclific');
|
|
9
|
+
const CONFIG_FILE = path.join(CONFIG_DIR, 'config.json');
|
|
10
|
+
export let config = {};
|
|
7
11
|
const command = process.argv[2];
|
|
8
12
|
if (command === 'init') {
|
|
13
|
+
// create config file
|
|
14
|
+
mkdir(CONFIG_DIR, { recursive: true })
|
|
15
|
+
.then(() => {
|
|
16
|
+
console.log(`Created directory: ${CONFIG_DIR}`);
|
|
17
|
+
process.exit(0);
|
|
18
|
+
})
|
|
19
|
+
.catch((error) => {
|
|
20
|
+
console.error('Failed to create directory:', error);
|
|
21
|
+
process.exit(1);
|
|
22
|
+
});
|
|
23
|
+
// create doclific directory
|
|
9
24
|
const cwd = process.cwd();
|
|
10
25
|
const doclificDir = path.join(cwd, 'doclific');
|
|
11
26
|
if (existsSync(doclificDir)) {
|
|
@@ -22,7 +37,22 @@ if (command === 'init') {
|
|
|
22
37
|
process.exit(1);
|
|
23
38
|
});
|
|
24
39
|
}
|
|
40
|
+
else if (command === 'set') {
|
|
41
|
+
const config = await readConfig();
|
|
42
|
+
const key = process.argv[3];
|
|
43
|
+
const value = process.argv[4];
|
|
44
|
+
setNested(config, key, value);
|
|
45
|
+
await writeConfig(config);
|
|
46
|
+
console.log(`Set ${key} to ${value}`);
|
|
47
|
+
process.exit(0);
|
|
48
|
+
}
|
|
49
|
+
else if (command === 'get') {
|
|
50
|
+
const config = await readConfig();
|
|
51
|
+
console.log(config);
|
|
52
|
+
process.exit(0);
|
|
53
|
+
}
|
|
25
54
|
else {
|
|
55
|
+
config = await readConfig();
|
|
26
56
|
const port = process.argv
|
|
27
57
|
.find((arg) => arg.startsWith('-p=') || arg.startsWith('--port='))
|
|
28
58
|
?.split('=')[1] || 6767;
|
|
@@ -32,3 +62,22 @@ else {
|
|
|
32
62
|
// Optional: open browser automatically
|
|
33
63
|
open(`http://localhost:${port}`);
|
|
34
64
|
}
|
|
65
|
+
export async function readConfig() {
|
|
66
|
+
if (!existsSync(CONFIG_FILE))
|
|
67
|
+
return {};
|
|
68
|
+
return JSON.parse(await readFile(CONFIG_FILE, 'utf8'));
|
|
69
|
+
}
|
|
70
|
+
async function writeConfig(config) {
|
|
71
|
+
await mkdir(CONFIG_DIR, { recursive: true });
|
|
72
|
+
await writeFile(CONFIG_FILE, JSON.stringify(config, null, 2));
|
|
73
|
+
}
|
|
74
|
+
function setNested(obj, key, value) {
|
|
75
|
+
var _a;
|
|
76
|
+
const parts = key.split('.');
|
|
77
|
+
let current = obj;
|
|
78
|
+
for (let i = 0; i < parts.length - 1; i++) {
|
|
79
|
+
current[_a = parts[i]] ?? (current[_a] = {});
|
|
80
|
+
current = current[parts[i]];
|
|
81
|
+
}
|
|
82
|
+
current[parts.at(-1)] = value;
|
|
83
|
+
}
|
package/dist/core/ai.js
ADDED
|
@@ -0,0 +1,140 @@
|
|
|
1
|
+
import { createOpenAI } from '@ai-sdk/openai';
|
|
2
|
+
import { createAnthropic } from '@ai-sdk/anthropic';
|
|
3
|
+
import { createGoogleGenerativeAI } from '@ai-sdk/google';
|
|
4
|
+
import { generateText, Output, stepCountIs, tool } from 'ai';
|
|
5
|
+
import { z } from 'zod';
|
|
6
|
+
import { getFileContents, getFlatFileList } from './codebase.js';
|
|
7
|
+
import { config } from '../bin/doclific.js';
|
|
8
|
+
export { tool };
|
|
9
|
+
const textNodeSchema = z.object({
|
|
10
|
+
nodeType: z.literal('text'),
|
|
11
|
+
type: z.enum(['p', 'h1', 'h2', 'h3']),
|
|
12
|
+
text: z.string(),
|
|
13
|
+
});
|
|
14
|
+
const codebaseSnippetSchema = z.object({
|
|
15
|
+
nodeType: z.literal('codebase snippet'), // better for the AI to understand
|
|
16
|
+
filePath: z.string(),
|
|
17
|
+
lineStart: z.number(),
|
|
18
|
+
lineEnd: z.number(),
|
|
19
|
+
});
|
|
20
|
+
const listNodeSchema = z.object({
|
|
21
|
+
nodeType: z.literal('list'),
|
|
22
|
+
type: z.enum(['numbered', 'bulleted']),
|
|
23
|
+
items: z.array(z.string()),
|
|
24
|
+
});
|
|
25
|
+
const richTextSchema = z.union([textNodeSchema, codebaseSnippetSchema, listNodeSchema]);
|
|
26
|
+
const getFileContentsTool = {
|
|
27
|
+
description: 'Get the contents of a file by file path. Multiple file paths can be provided.',
|
|
28
|
+
inputSchema: z.object({
|
|
29
|
+
filePaths: z.array(z.string()),
|
|
30
|
+
}),
|
|
31
|
+
execute: async ({ filePaths }) => {
|
|
32
|
+
const contents = await Promise.all(filePaths.map(async (filePath) => {
|
|
33
|
+
const contents = await getFileContents(filePath);
|
|
34
|
+
return {
|
|
35
|
+
filePath,
|
|
36
|
+
contents: contents
|
|
37
|
+
.split('\n')
|
|
38
|
+
.map((line, index) => `${index + 1}: ${line}`)
|
|
39
|
+
.join('\n'),
|
|
40
|
+
};
|
|
41
|
+
}));
|
|
42
|
+
return contents;
|
|
43
|
+
},
|
|
44
|
+
};
|
|
45
|
+
export class AIModel {
|
|
46
|
+
constructor() {
|
|
47
|
+
this.model = this.createModel();
|
|
48
|
+
this.model = this.createModel();
|
|
49
|
+
}
|
|
50
|
+
async generateRichText(prompt) {
|
|
51
|
+
const fileContents = await getFlatFileList();
|
|
52
|
+
const result = await generateText({
|
|
53
|
+
model: this.model,
|
|
54
|
+
system: `
|
|
55
|
+
When writing documentation:
|
|
56
|
+
1. Explain concepts using "text" nodes
|
|
57
|
+
2. Reference implementation using "codebase snippet" nodes
|
|
58
|
+
3. Use "list" nodes only for summaries
|
|
59
|
+
|
|
60
|
+
If you need to show code, DO NOT paste it — reference it.
|
|
61
|
+
|
|
62
|
+
The project structure is: ${fileContents.join('\n')}
|
|
63
|
+
`,
|
|
64
|
+
experimental_output: Output.object({
|
|
65
|
+
schema: z.object({
|
|
66
|
+
nodes: z.array(richTextSchema),
|
|
67
|
+
}),
|
|
68
|
+
}),
|
|
69
|
+
tools: {
|
|
70
|
+
getFileContents: tool(getFileContentsTool),
|
|
71
|
+
},
|
|
72
|
+
stopWhen: stepCountIs(10),
|
|
73
|
+
prompt,
|
|
74
|
+
});
|
|
75
|
+
return result;
|
|
76
|
+
}
|
|
77
|
+
createModel() {
|
|
78
|
+
const provider = config.AI_PROVIDER;
|
|
79
|
+
const modelName = config.AI_MODEL;
|
|
80
|
+
if (!provider) {
|
|
81
|
+
throw new Error('You must set AI_PROVIDER environment variable to one of the following: openai, anthropic, google');
|
|
82
|
+
}
|
|
83
|
+
switch (provider) {
|
|
84
|
+
case 'openai': {
|
|
85
|
+
const openai = createOpenAI({ apiKey: config.OPENAI_API_KEY });
|
|
86
|
+
if (!modelName) {
|
|
87
|
+
throw new Error('You must set AI_MODEL environment variable');
|
|
88
|
+
}
|
|
89
|
+
return openai(modelName);
|
|
90
|
+
}
|
|
91
|
+
case 'anthropic': {
|
|
92
|
+
const anthropic = createAnthropic({ apiKey: config.ANTHROPIC_API_KEY });
|
|
93
|
+
if (!modelName) {
|
|
94
|
+
throw new Error('You must set AI_MODEL environment variable');
|
|
95
|
+
}
|
|
96
|
+
return anthropic(modelName);
|
|
97
|
+
}
|
|
98
|
+
case 'google': {
|
|
99
|
+
const google = createGoogleGenerativeAI({ apiKey: config.GOOGLE_API_KEY });
|
|
100
|
+
if (!modelName) {
|
|
101
|
+
throw new Error('You must set AI_MODEL environment variable');
|
|
102
|
+
}
|
|
103
|
+
return google(modelName);
|
|
104
|
+
}
|
|
105
|
+
default:
|
|
106
|
+
throw new Error('Unsupported provider; You must set AI_PROVIDER environment variable to one of the following: openai, anthropic, google');
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
export function serializeCustomRichTextNodes(nodes) {
|
|
111
|
+
return nodes
|
|
112
|
+
.map((node) => {
|
|
113
|
+
switch (node.nodeType) {
|
|
114
|
+
case 'text':
|
|
115
|
+
return {
|
|
116
|
+
type: node.type,
|
|
117
|
+
children: [{ text: node.text }],
|
|
118
|
+
};
|
|
119
|
+
case 'codebase snippet':
|
|
120
|
+
return {
|
|
121
|
+
type: 'CodebaseSnippet',
|
|
122
|
+
filePath: node.filePath,
|
|
123
|
+
lineStart: node.lineStart,
|
|
124
|
+
lineEnd: node.lineEnd,
|
|
125
|
+
children: [{ text: '' }],
|
|
126
|
+
};
|
|
127
|
+
case 'list':
|
|
128
|
+
const listItems = node.items.map((item) => {
|
|
129
|
+
return {
|
|
130
|
+
type: 'p',
|
|
131
|
+
children: [{ text: item }],
|
|
132
|
+
indent: 1,
|
|
133
|
+
listStyleType: node.type,
|
|
134
|
+
};
|
|
135
|
+
});
|
|
136
|
+
return listItems;
|
|
137
|
+
}
|
|
138
|
+
})
|
|
139
|
+
.flat();
|
|
140
|
+
}
|
package/dist/core/codebase.js
CHANGED
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
import path from 'path';
|
|
2
2
|
import fs from 'fs/promises';
|
|
3
|
+
import { existsSync } from 'fs';
|
|
4
|
+
import ignore from 'ignore';
|
|
3
5
|
/**
|
|
4
6
|
* Get all contents of a folder given a filePath.
|
|
5
7
|
* @param filePath - The relative path to the folder
|
|
@@ -25,7 +27,51 @@ export const getFolderContents = async (filePath) => {
|
|
|
25
27
|
return nodes;
|
|
26
28
|
};
|
|
27
29
|
export const getFileContents = async (filePath) => {
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
30
|
+
try {
|
|
31
|
+
const currentDir = process.cwd();
|
|
32
|
+
const fullPath = path.join(currentDir, filePath);
|
|
33
|
+
return fs.readFile(fullPath, 'utf8');
|
|
34
|
+
}
|
|
35
|
+
catch (error) {
|
|
36
|
+
throw new Error(`Failed to get file contents for ${filePath}: ${error}`);
|
|
37
|
+
}
|
|
31
38
|
};
|
|
39
|
+
/**
|
|
40
|
+
* Recursively scans a directory and returns a flat list of all file paths
|
|
41
|
+
* @param {string} dir - Directory path to scan
|
|
42
|
+
* @param {string[]} fileList - Accumulator for file paths
|
|
43
|
+
* @param {string} baseDir - Base directory for relative paths
|
|
44
|
+
* @param {ignore.Ignore} ignoreInstance - Ignore instance for .gitignore patterns
|
|
45
|
+
* @returns {string[]} - Array of relative paths
|
|
46
|
+
*/
|
|
47
|
+
export async function getFlatFileList(dir = process.cwd(), fileList = [], baseDir = dir, ignoreInstance) {
|
|
48
|
+
// Load .gitignore on first call
|
|
49
|
+
if (!ignoreInstance) {
|
|
50
|
+
const gitignorePath = path.join(baseDir, '.gitignore');
|
|
51
|
+
let gitignoreContent = '';
|
|
52
|
+
if (existsSync(gitignorePath)) {
|
|
53
|
+
gitignoreContent = await fs.readFile(gitignorePath, 'utf8');
|
|
54
|
+
}
|
|
55
|
+
ignoreInstance = ignore().add(gitignoreContent);
|
|
56
|
+
}
|
|
57
|
+
const items = await fs.readdir(dir, { withFileTypes: true });
|
|
58
|
+
for (const item of items) {
|
|
59
|
+
const fullPath = path.join(dir, item.name);
|
|
60
|
+
const relativePath = path.relative(baseDir, fullPath);
|
|
61
|
+
const stats = await fs.stat(fullPath);
|
|
62
|
+
// Check if path should be ignored
|
|
63
|
+
if (ignoreInstance.ignores(relativePath) || relativePath.startsWith('.git')) {
|
|
64
|
+
continue;
|
|
65
|
+
}
|
|
66
|
+
if (stats.isDirectory()) {
|
|
67
|
+
// Include directory path itself
|
|
68
|
+
fileList.push(relativePath + '/');
|
|
69
|
+
// Recurse into the subdirectory
|
|
70
|
+
await getFlatFileList(fullPath, fileList, baseDir, ignoreInstance);
|
|
71
|
+
}
|
|
72
|
+
else {
|
|
73
|
+
fileList.push(relativePath);
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
return fileList;
|
|
77
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{r as g,v as a}from"./index-Cr2gUYn7.js";const d="64px",u={},k=({src:s,light:t,oEmbedUrl:o,onClickPreview:r,playIcon:b,previewTabIndex:v,previewAriaLabel:p})=>{const[f,n]=g.useState(null);g.useEffect(()=>{!s||!t||!o||_({src:s,light:t,oEmbedUrl:o})},[s,t,o]);const _=async({src:e,light:c,oEmbedUrl:E})=>{if(a.isValidElement(c))return;if(typeof c=="string"){n(c);return}if(u[e]){n(u[e]);return}n(null);const m=await(await fetch(E.replace("{url}",e))).json();if(m.thumbnail_url){const h=m.thumbnail_url.replace("height=100","height=480").replace("-d_295x166","-d_640");n(h),u[e]=h}},x=e=>{(e.key==="Enter"||e.key===" ")&&r?.(e)},I=e=>{r?.(e)},l=a.isValidElement(t),y={display:"flex",alignItems:"center",justifyContent:"center"},i={preview:{width:"100%",height:"100%",backgroundImage:f&&!l?`url(${f})`:void 0,backgroundSize:"cover",backgroundPosition:"center",cursor:"pointer",...y},shadow:{background:"radial-gradient(rgb(0, 0, 0, 0.3), rgba(0, 0, 0, 0) 60%)",borderRadius:d,width:d,height:d,position:l?"absolute":void 0,...y},playIcon:{borderStyle:"solid",borderWidth:"16px 0 16px 26px",borderColor:"transparent transparent transparent white",marginLeft:"7px"}},w=a.createElement("div",{style:i.shadow,className:"react-player__shadow"},a.createElement("div",{style:i.playIcon,className:"react-player__play-icon"}));return a.createElement("div",{style:i.preview,className:"react-player__preview",tabIndex:v,onClick:I,onKeyPress:x,...p?{"aria-label":p}:{}},l?t:null,b||w)};var C=k;export{C as default};
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import"./percentages-BXMCSKIN-DmjnxD3b.js";import"./index-Cr2gUYn7.js";var u={paste:"لصق",pasteAsPlaintext:"اللصق كنص عادي",pasteCharts:"لصق الرسوم البيانية",selectAll:"تحديد الكل",multiSelect:"إضافة عنصر للتحديد",moveCanvas:"نقل لوح الرسم",cut:"قص",copy:"نسخ",copyAsPng:"نسخ إلى الحافظة بصيغة PNG",copyAsSvg:"نسخ إلى الحافظة بصيغة SVG",copyText:"نسخ إلى الحافظة كنص",copySource:"",convertToCode:"",bringForward:"جلب للأمام",sendToBack:"أرسل للخلف",bringToFront:"أحضر للأمام",sendBackward:"أرسل للخلف",delete:"حذف",copyStyles:"نسخ الأنماط",pasteStyles:"لصق الأنماط",stroke:"الخط",background:"الخلفية",fill:"التعبئة",strokeWidth:"سُمك الخط",strokeStyle:"نمط الخط",strokeStyle_solid:"متصل",strokeStyle_dashed:"متقطع",strokeStyle_dotted:"منقط",sloppiness:"الإمالة",opacity:"الشفافية",textAlign:"محاذاة النص",edges:"الحواف",sharp:"حادة",round:"دائرية",arrowheads:"رؤوس الأسهم",arrowhead_none:"لا شيء",arrowhead_arrow:"سهم",arrowhead_bar:"شريط",arrowhead_circle:"",arrowhead_circle_outline:"",arrowhead_triangle:"مثلث",arrowhead_triangle_outline:"",arrowhead_diamond:"",arrowhead_diamond_outline:"",fontSize:"حجم الخط",fontFamily:"نوع الخط",addWatermark:'إضافة "مصنوعة بواسطة Excalidraw"',handDrawn:"رسم باليد",normal:"عادي",code:"رمز",small:"صغير",medium:"متوسط",large:"كبير",veryLarge:"كبير جدا",solid:"كامل",hachure:"خطوط",zigzag:"متعرج",crossHatch:"خطوط متقطعة",thin:"نحيف",bold:"داكن",left:"الـيسار",center:"وسط",right:"يمين",extraBold:"عريض",architect:"معماري",artist:"رسام",cartoonist:"كرتوني",fileTitle:"إسم الملف",colorPicker:"منتقي اللون",canvasColors:"تستخدم على القماش",canvasBackground:"خلفية اللوحة",drawingCanvas:"لوحة الرسم",layers:"الطبقات",actions:"الإجراءات",language:"اللغة",liveCollaboration:"التعاون المباشر...",duplicateSelection:"تكرار",untitled:"غير معنون",name:"الاسم",yourName:"اسمك",madeWithExcalidraw:"مصنوعة بواسطة Excalidraw",group:"تحديد مجموعة",ungroup:"إلغاء تحديد مجموعة",collaborators:"المتعاونون",showGrid:"إظهار الشبكة",addToLibrary:"أضف إلى المكتبة",removeFromLibrary:"حذف من المكتبة",libraryLoadingMessage:"جارٍ تحميل المكتبة…",libraries:"تصفح المكتبات",loadingScene:"جاري تحميل المشهد…",align:"محاذاة",alignTop:"محاذاة إلى اﻷعلى",alignBottom:"محاذاة إلى اﻷسفل",alignLeft:"محاذاة إلى اليسار",alignRight:"محاذاة إلى اليمين",centerVertically:"توسيط عمودي",centerHorizontally:"توسيط أفقي",distributeHorizontally:"التوزيع الأفقي",distributeVertically:"التوزيع عمودياً",flipHorizontal:"قلب عامودي",flipVertical:"قلب أفقي",viewMode:"نمط العرض",share:"مشاركة",showStroke:"إظهار منتقي لون الخط",showBackground:"إظهار منتقي لون الخلفية",toggleTheme:"غير النمط",personalLib:"المكتبة الشخصية",excalidrawLib:"مكتبتنا",decreaseFontSize:"تصغير حجم الخط",increaseFontSize:"تكبير حجم الخط",unbindText:"فك ربط النص",bindText:"ربط النص بالحاوية",createContainerFromText:"نص مغلف في حاوية",link:{edit:"تعديل الرابط",editEmbed:"تحرير الرابط وإدراجه",create:"إنشاء رابط",createEmbed:"إنشاء رابط و إدراجه",label:"رابط",labelEmbed:"رابط و إدراج",empty:"لم يتم تعيين رابط"},lineEditor:{edit:"تحرير السطر",exit:"الخروج من المُحرر"},elementLock:{lock:"قفل",unlock:"فتح",lockAll:"قفل الكل",unlockAll:"فتح الكل"},statusPublished:"نُشر",sidebarLock:"إبقاء الشريط الجانبي مفتوح",selectAllElementsInFrame:"تحديد جميع العناصر في الإطار",removeAllElementsFromFrame:"إزالة جميع العناصر من الإطار",eyeDropper:"اختيار اللون من القماش",textToDiagram:"",prompt:""},A={noItems:"لا توجد عناصر أضيفت بعد...",hint_emptyLibrary:"حدد عنصر على القماش لإضافته هنا، أو تثبيت مكتبة من المستودع العام أدناه.",hint_emptyPrivateLibrary:"حدد عنصر على القماش لإضافته هنا."},e={clearReset:"إعادة تعيين اللوحة",exportJSON:"صدر الملف",exportImage:"تصدير الصورة...",export:"حفظ إلى...",copyToClipboard:"نسخ إلى الحافظة",save:"احفظ للملف الحالي",saveAs:"حفظ كـ",load:"فتح",getShareableLink:"احصل على رابط المشاركة",close:"غلق",selectLanguage:"اختر اللغة",scrollBackToContent:"الرجوع إلى المحتوى",zoomIn:"تكبير",zoomOut:"تصغير",resetZoom:"إعادة تعيين الشاشة",menu:"القائمة",done:"تم",edit:"تعديل",undo:"تراجع",redo:"إعادة تنفيذ",resetLibrary:"إعادة ضبط المكتبة",createNewRoom:"إنشاء غرفة جديدة",fullScreen:"شاشة كاملة",darkMode:"الوضع المظلم",lightMode:"الوضع المضيء",zenMode:"وضع التأمل",objectsSnapMode:"التقط إلى العناصر",exitZenMode:"إلغاء الوضع الليلى",cancel:"إلغاء",clear:"مسح",remove:"إزالة",embed:"تبديل الإدراج",publishLibrary:"انشر",submit:"أرسل",confirm:"تأكيد",embeddableInteractionButton:"اضغط للتفاعل"},a={clearReset:"هذا سيُزيل كامل اللوحة. هل أنت متأكد؟",couldNotCreateShareableLink:"تعذر إنشاء رابطة المشاركة.",couldNotCreateShareableLinkTooBig:"تعذر إنشاء رابط قابل للمشاركة: المشهد كبير جدًا",couldNotLoadInvalidFile:"تعذر التحميل، الملف غير صالح",importBackendFailed:"فشل الاستيراد من الخادوم.",cannotExportEmptyCanvas:"لا يمكن تصدير لوحة فارغة.",couldNotCopyToClipboard:"تعذر النسخ إلى الحافظة.",decryptFailed:"تعذر فك تشفير البيانات.",uploadedSecurly:"تم تأمين التحميل بتشفير النهاية إلى النهاية، مما يعني أن خادوم Excalidraw والأطراف الثالثة لا يمكنها قراءة المحتوى.",loadSceneOverridePrompt:"تحميل الرسم الخارجي سيحل محل المحتوى الموجود لديك. هل ترغب في المتابعة؟",collabStopOverridePrompt:`إيقاف الجلسة سيؤدي إلى الكتابة فوق رسومك السابقة المخزنة داخليا. هل أنت متأكد؟
|
|
2
|
+
|
|
3
|
+
(إذا كنت ترغب في الاحتفاظ برسمك المخزن داخليا، ببساطة أغلق علامة تبويب المتصفح بدلاً من ذلك.)`,errorAddingToLibrary:"تعذر إضافة العنصر للمكتبة",errorRemovingFromLibrary:"تعذر إزالة العنصر من المكتبة",confirmAddLibrary:"هذا سيضيف {{numShapes}} شكل إلى مكتبتك. هل أنت متأكد؟",imageDoesNotContainScene:"يبدو أن هذه الصورة لا تحتوي على أي بيانات مشهد. هل قمت بتمكين تضمين المشهد أثناء التصدير؟",cannotRestoreFromImage:"تعذر استعادة المشهد من ملف الصورة",invalidSceneUrl:"تعذر استيراد المشهد من عنوان URL المتوفر. إما أنها مشوهة، أو لا تحتوي على بيانات Excalidraw JSON صالحة.",resetLibrary:"هذا سوف يمسح مكتبتك. هل أنت متأكد؟",removeItemsFromsLibrary:"حذف {{count}} عنصر (عناصر) من المكتبة؟",invalidEncryptionKey:"مفتاح التشفير يجب أن يكون من 22 حرفاً. التعاون المباشر معطل.",collabOfflineWarning:`لا يوجد اتصال بالانترنت.
|
|
4
|
+
لن يتم حفظ التغييرات التي قمت بها!`},r={unsupportedFileType:"نوع الملف غير مدعوم.",imageInsertError:"تعذر إدراج الصورة. حاول مرة أخرى لاحقاً...",fileTooBig:"الملف كبير جداً. الحد الأقصى المسموح به للحجم هو {{maxSize}}.",svgImageInsertError:"تعذر إدراج صورة SVG. يبدو أن ترميز SVG غير صحيح.",failedToFetchImage:"",invalidSVGString:"SVG غير صالح.",cannotResolveCollabServer:"تعذر الاتصال بخادم التعاون. الرجاء إعادة تحميل الصفحة والمحاولة مرة أخرى.",importLibraryError:"تعذر تحميل المكتبة",collabSaveFailed:"تعذر الحفظ في قاعدة البيانات. إذا استمرت المشاكل، يفضل أن تحفظ ملفك محليا كي لا تفقد عملك.",collabSaveFailed_sizeExceeded:"تعذر الحفظ في قاعدة البيانات، يبدو أن القماش كبير للغاية، يفضّل حفظ الملف محليا كي لا تفقد عملك.",imageToolNotSupported:"",brave_measure_text_error:{line1:"يبدو أنك تستخدم متصفح Brave مع إعداد <bold>حظر صارم لتتبع البصمة</bold>.",line2:"قد يؤدي هذا إلى كسر <bold>عناصر النص</bold> في الرسومات الخاصة بك.",line3:"من المستحسن إلغاء تفعيل هذا الإعداد. يمكنك اتباع <link>هذه الخطوات</link> لفعل ذلك.",line4:"إذا لم يصلح تعطيل هذا الإعداد طريقة عرض النصوص، الرجاء كتابة <issueLink>بلاغ</issueLink> على حسابنا في GitHub، أو راسلنا على <discordLink>Discord</discordLink>"},libraryElementTypeError:{embeddable:"لا يمكن إضافة العناصر القابلة للتضمين في المكتبة.",iframe:"",image:"سوف يتم دعم إضافة صور إلى المكتبة قريباً!"},asyncPasteFailedOnRead:"",asyncPasteFailedOnParse:"",copyToSystemClipboardFailed:""},o={selection:"تحديد",image:"إدراج صورة",rectangle:"مستطيل",diamond:"مضلع",ellipse:"دائرة",arrow:"سهم",line:"خط",freedraw:"رسم",text:"نص",library:"مكتبة",lock:"الحفاظ على أداة التحديد نشطة بعد الرسم",penMode:"وضع القلم - امنع اللمس",link:"إضافة/تحديث الرابط للشكل المحدد",eraser:"ممحاة",frame:"أداة الإطار",magicframe:"",embeddable:"تضمين ويب",laser:"مؤشر ليزر",hand:"يد (أداة الإزاحة)",extraTools:"المزيد من أﻷدوات",mermaidToExcalidraw:"",magicSettings:""},t={canvasActions:"إجراءات اللوحة",selectedShapeActions:"إجراءات الشكل المحدد",shapes:"الأشكال"},i={canvasPanning:"لتحريك القماش، اضغط على عجلة الفأرة أو مفتاح المسافة أثناء السحب، أو استخدم أداة اليد",linearElement:"انقر لبدء نقاط متعددة، اسحب لخط واحد",freeDraw:"انقر واسحب، افرج عند الانتهاء",text:"نصيحة: يمكنك أيضًا إضافة نص بالنقر المزدوج في أي مكان بأداة الاختيار",embeddable:"اضغط مع السحب لإنشاء موقع ويب مضمّن",text_selected:"انقر نقراً مزدوجاً أو اضغط ادخال لتعديل النص",text_editing:"اضغط على Esc أو (Ctrl أو Cmd) + Enter لإنهاء التعديل",linearElementMulti:"انقر فوق النقطة الأخيرة أو اضغط على Esc أو Enter للإنهاء",lockAngle:"يمكنك تقييد الزاوية بالضغط على SHIFT",resize:`يمكنك تقييد النسب بالضغط على SHIFT أثناء تغيير الحجم،
|
|
5
|
+
اضغط على ALT لتغيير الحجم من المركز`,resizeImage:`يمكنك تغيير الحجم بحرية بالضغط بأستمرار على SHIFT،
|
|
6
|
+
اضغط بأستمرار على ALT أيضا لتغيير الحجم من المركز`,rotate:"يمكنك تقييد الزوايا من خلال الضغط على SHIFT أثناء الدوران",lineEditor_info:"اضغط على مفتاح (Ctrl أو Cmd) و انقر بشكل مزدوج، أو اضغط على مفتاحي (Ctrl أو Cmd) و (Enter) لتعديل النقاط",lineEditor_pointSelected:"اضغط على حذف لإزالة النقطة (النِّقَاط)، Ctrl/Cmd+D للتكرار، أو اسحب للانتقال",lineEditor_nothingSelected:`اختر نقطة لتعديلها (اضغط على SHIFT لتحديد عدة نِقَاط),
|
|
7
|
+
أو اضغط على ALT و انقر بالفأرة لإضافة نِقَاط جديدة`,placeImage:"انقر لوضع الصورة، أو انقر واسحب لتعيين حجمها يدوياً",publishLibrary:"نشر مكتبتك",bindTextToElement:"اضغط على إدخال لإضافة نص",deepBoxSelect:"اضغط على Ctrl\\Cmd للاختيار العميق، ولمنع السحب",eraserRevert:"اضغط على Alt لاستعادة العناصر المعلَّمة للحذف",firefox_clipboard_write:'يمكن على الأرجح تمكين هذه الميزة عن طريق تعيين علم "dom.events.asyncClipboard.clipboardItem" إلى "true". لتغيير أعلام المتصفح في Firefox، قم بزيارة صفحة "about:config".',disableSnapping:"اضغط على Ctrl أو Cmd لتعطيل الالتقاط"},l={cannotShowPreview:"تعذر عرض المعاينة",canvasTooBig:"قد تكون اللوحة كبيرة جداً.",canvasTooBigTip:"نصيحة: حاول تحريك العناصر البعيدة بشكل أقرب قليلاً."},F={headingMain:"حدث خطأ. حاول <button>تحديث الصفحة</button>.",clearCanvasMessage:"إذا لم تعمل إعادة التحميل، حاول مرة أخرى ",clearCanvasCaveat:" هذا سيؤدي إلى فقدان العمل ",trackedToSentry:"تم تتبع الخطأ في المعرف {{eventId}} على نظامنا.",openIssueMessage:"حرصنا على عدم إضافة معلومات المشهد في بلاغ الخطأ. في حال كون مشهدك لا يحمل أي معلومات خاصة نرجو المتابعة على <button>نظام تتبع الأخطاء</button>. نرجو إضافة المعلومات أدناه بنسخها ولصقها في محتوى البلاغ على GitHub.",sceneContent:"محتوى المشهد:"},n={desc_intro:"يمكنك دعوة الآخرين لمشاركتك نفس الجلسة التي تعمل عليها.",desc_privacy:"لا تقلق، الجلسة تستخدم التشفير من النهاية إلى النهاية، لذلك فإن أي شيء ترسمه سيبقى خاصاً. لن يتمكن حتى الخادوم الخاص بنا من رؤية ما توصلت إليه.",button_startSession:"بدء الجلسة",button_stopSession:"إيقاف الجلسة",desc_inProgressIntro:"تجري الآن المشاركة الحية.",desc_shareLink:"شارك هذا الرابط مع أي شخص تريده أن يشاركك الجلسة:",desc_exitSession:"إيقاف الجلسة سيؤدي إلى قطع الاتصال الخاص بك من الغرفة، ولكن ستتمكن من مواصلة العمل مع المشهد، محليا. لاحظ أن هذا لن يؤثر على الأشخاص الآخرين، و سيظلون قادرين على التعاون في إصدارهم.",shareTitle:"الانضمام إلى جلسة تعاون حية على Excalidraw"},s={title:"خطأ"},D={disk_title:"حفظ الملف للجهاز",disk_details:"تصدير بيانات المشهد إلى ملف يمكنك الاستيراد منه لاحقاً.",disk_button:"إحفظ لملف",link_title:"رابط قابل للمشاركة",link_details:"صدر الملف للمشاهدة فقط.",link_button:"التصدير كرابط",excalidrawplus_description:"حفظ المشهد إلى مساحة العمل +Excalidraw الخاصة بك.",excalidrawplus_button:"تصدير",excalidrawplus_exportError:"تعذر التصدير إلى +Excalidraw في الوقت الحالي..."},d={blog:"اقرأ مدونتنا",click:"انقر",deepSelect:"تحديد عميق",deepBoxSelect:"تحديد عميق داخل المربع، ومنع السحب",curvedArrow:"سهم مائل",curvedLine:"خط مائل",documentation:"دليل الاستخدام",doubleClick:"انقر مرتين",drag:"اسحب",editor:"المحرر",editLineArrowPoints:"تحرير سطر/نقاط سهم",editText:"تعديل النص / إضافة تسمية",github:"عثرت على مشكلة؟ إرسال",howto:"اتبع التعليمات",or:"أو",preventBinding:"منع ارتبط السهم",tools:"الأدوات",shortcuts:"اختصارات لوحة المفاتيح",textFinish:"إنهاء التعديل (محرر النص)",textNewLine:"أضف سطر جديد (محرر نص)",title:"المساعدة",view:"عرض",zoomToFit:"تكبير للملائمة",zoomToSelection:"تكبير للعنصر المحدد",toggleElementLock:"إغلاق/فتح المحدد",movePageUpDown:"نقل الصفحة أعلى/أسفل",movePageLeftRight:"نقل الصفحة يسار/يمين"},c={title:"مسح اللوحة"},C={title:"نشر المكتبة",itemName:"إسم العنصر",authorName:"إسم المؤلف",githubUsername:"اسم المستخدم في جيت هب",twitterUsername:"اسم المستخدم في تويتر",libraryName:"اسم المكتبة",libraryDesc:"وصف المكتبة",website:"الموقع",placeholder:{authorName:"اسمك أو اسم المستخدم",libraryName:"اسم مكتبتك",libraryDesc:"وصف مكتبتك لمساعدة الناس على فهم استخدامها",githubHandle:"معالج GitHub (اختياري)، حتى تتمكن من تحرير المكتبة عند إرسالها للمراجعة",twitterHandle:"اسم مستخدم تويتر (اختياري)، حتى نعرف من الذي سيتم الإشارة إليه عند الترويج عبر تويتر",website:"رابط إلى موقعك الشخصي أو في مكان آخر (اختياري)"},errors:{required:"مطلوب",website:"أدخل عنوان URL صالح"},noteDescription:"تقديم مكتبتك لتضمينها في مستودع المكتبة العامة <link></link> لأشخاص آخرين لاستخدامها في رسومهم.",noteGuidelines:"تحتاج المكتبة إلى الموافقة أولا. يرجى قراءة <link>المعايير</link> قبل تقديمها. سوف تحتاج إلى حساب GitHub للتواصل وإجراء التغييرات عند الطلب، ولكن ليس مطلوبا بشكل صارم.",noteLicense:"تقديمك يعني موافقتك على نشر المكتبة المقدمة تحت <link>MIT ترخيص</link>، ما يعني أن لأي أحد الحق في استخدامها دون قيود.",noteItems:"يجب أن يكون لكل عنصر مكتبة اسمه الخاص حتى يكون قابلاً للتصفية. سيتم تضمين عناصر المكتبة التالية:",atleastOneLibItem:"يرجى تحديد عنصر مكتبة واحد على الأقل للبدء",republishWarning:"ملاحظة: بعض العناصر المحددة معينة على أنه نشرها أو تقديمها من قبل. يجب عليك فقط إعادة إرسال العناصر عند تحديث مكتبة موجودة أو إرسالها."},E={title:"تم إرسال المكتبة",content:"شكرا لك {{authorName}}. لقد تم إرسال مكتبتك للمراجعة. يمكنك تتبع الحالة"},m={resetLibrary:"إعادة ضبط المكتبة",removeItemsFromLib:"إزالة العناصر المحددة من المكتبة"},b={header:"تصدير الصورة",label:{withBackground:"الخلفية",onlySelected:"المحدد فقط",darkMode:"الوضع الداكن",embedScene:"تضمين المشهد",scale:"الحجم",padding:"الهوامش"},tooltip:{embedScene:`سيتم حفظ بيانات المشهد في ملف PNG/SVG المصدّر بحيث يمكن استعادة المشهد منه.
|
|
8
|
+
سيزيد حجم الملف المصدر.`},title:{exportToPng:"تصدير بصيغة PNG",exportToSvg:"تصدير بصيغة SVG",copyPngToClipboard:"نسخ الـ PNG إلى الحافظة"},button:{exportToPng:"PNG",exportToSvg:"SVG",copyPngToClipboard:"نسخ إلى الحافظة"}},p={tooltip:"رسوماتك مشفرة من النهاية إلى النهاية حتى أن خوادم Excalidraw لن تراها أبدا.",link:"مشاركة المدونة في التشفير من النهاية إلى النهاية في Excalidraw"},g={angle:"الزاوية",element:"عنصر",elements:"العناصر",height:"الارتفاع",scene:"المشهد",selected:"المحدد",storage:"التخزين",title:"إحصائيات للمهووسين",total:"المجموع",version:"الإصدار",versionCopy:"انقر للنسخ",versionNotAvailable:"الإصدار غير متوفر",width:"العرض"},h={addedToLibrary:"تمت الاضافة الى المكتبة!",copyStyles:"نسخت الانماط.",copyToClipboard:"نسخ إلى الحافظة.",copyToClipboardAsPng:`تم نسخ {{exportSelection}} إلى الحافظة بصيغة PNG
|
|
9
|
+
({{exportColorScheme}})`,fileSaved:"تم حفظ الملف.",fileSavedToFilename:"حفظ باسم {filename}",canvas:"لوحة الرسم",selection:"العنصر المحدد",pasteAsSingleElement:`استخدم {{shortcut}} للصق كعنصر واحد،
|
|
10
|
+
أو لصق في محرر نص موجود`,unableToEmbed:"تضمين هذا الرابط غير مسموح حاليًا. افتح بلاغاً على GitHub لطلب عنوان Url القائمة البيضاء",unrecognizedLinkFormat:"الرابط الذي ضمنته لا يتطابق مع التنسيق المتوقع. الرجاء محاولة لصق النص 'المضمن' المُزوَد من موقع المصدر"},S={transparent:"شفاف",black:"أسود",white:"أبيض",red:"أحمر",pink:"وردي",grape:"عنبي",violet:"بنفسجي",gray:"رمادي",blue:"أزرق",cyan:"سماوي",teal:"أزرق مخضر",green:"أخضر",yellow:"أصفر",orange:"برتقالي",bronze:"برونزي"},y={app:{center_heading:"جميع بياناتك محفوظة محليا في المتصفح الخاص بك.",center_heading_plus:"هل تريد الذهاب إلى Excalidraw+ بدلاً من ذلك؟",menuHint:"التصدير والتفضيلات واللغات ..."},defaults:{menuHint:"التصدير والتفضيلات وغيرها...",center_heading:"الرسم البياني التصويري. بشكل مبسط.",toolbarHint:"اختر أداة و ابدأ الرسم!",helpHint:"الاختصارات و المساعدة"}},v={mostUsedCustomColors:"الألوان المخصصة الأكثر استخداما",colors:"الألوان",shades:"الدرجات",hexCode:"رمز Hex",noShades:"لا تتوفر درجات لهذا اللون"},x={action:{exportToImage:{title:"تصدير كصورة",button:"تصدير كصورة",description:"تصدير بيانات المشهد إلى ملف يمكنك الاستيراد منه لاحقاً."},saveToDisk:{title:"حفظ الملف للجهاز",button:"حفظ الملف للجهاز",description:"تصدير بيانات المشهد إلى ملف يمكنك الاستيراد منه لاحقاً."},excalidrawPlus:{title:"Excalidraw+",button:"تصدير إلى Excalidraw+",description:"حفظ المشهد إلى مساحة العمل +Excalidraw الخاصة بك."}},modal:{loadFromFile:{title:"تحميل من ملف",button:"تحميل من ملف",description:"سيتم التحميل من الملف <bold>استبدال المحتوى الموجود</bold>.<br></br>يمكنك النسخ الاحتياطي لرسمك أولاً باستخدام أحد الخيارات أدناه."},shareableLink:{title:"تحميل من رابط",button:"استبدال محتواي",description:"سيتسبب تحميل رسمة خارجية <bold>باستبدال محتواك الموجود حالياً</bold>.<br></br>بإمكانك إجراء النسخ الاحتياطي لرسمتك الحالية باستخدام أحد الخيارات أدناه."}}},w={title:"",button:"",description:"",syntax:"",preview:""},T={labels:u,library:A,buttons:e,alerts:a,errors:r,toolBar:o,headings:t,hints:i,canvasError:l,errorSplash:F,roomDialog:n,errorDialog:s,exportDialog:D,helpDialog:d,clearCanvasDialog:c,publishDialog:C,publishSuccessDialog:E,confirmDialog:m,imageExportDialog:b,encrypted:p,stats:g,toast:h,colors:S,welcomeScreen:y,colorPicker:v,overwriteConfirm:x,mermaid:w};export{a as alerts,e as buttons,l as canvasError,c as clearCanvasDialog,v as colorPicker,S as colors,m as confirmDialog,T as default,p as encrypted,s as errorDialog,F as errorSplash,r as errors,D as exportDialog,t as headings,d as helpDialog,i as hints,b as imageExportDialog,u as labels,A as library,w as mermaid,x as overwriteConfirm,C as publishDialog,E as publishSuccessDialog,n as roomDialog,g as stats,h as toast,o as toolBar,y as welcomeScreen};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{w as ln,c as H}from"./path-CbwjOpE9.js";import{B as rn,D as M,E as D,F as an,G as y,H as on,I as j,J as _,K as un,L as t,M as sn,N as tn,O as fn}from"./index-Bu97Fipb.js";function cn(l){return l.innerRadius}function yn(l){return l.outerRadius}function gn(l){return l.startAngle}function mn(l){return l.endAngle}function pn(l){return l&&l.padAngle}function dn(l,h,O,E,v,A,J,r){var q=O-l,i=E-h,n=J-v,m=r-A,a=m*q-n*i;if(!(a*a<y))return a=(n*(h-A)-m*(l-v))/a,[l+a*q,h+a*i]}function W(l,h,O,E,v,A,J){var r=l-O,q=h-E,i=(J?A:-A)/j(r*r+q*q),n=i*q,m=-i*r,a=l+n,s=h+m,f=O+n,c=E+m,K=(a+f)/2,o=(s+c)/2,p=f-a,g=c-s,R=p*p+g*g,T=v-A,P=a*c-f*s,B=(g<0?-1:1)*j(tn(0,T*T*R-P*P)),F=(P*g-p*B)/R,G=(-P*p-g*B)/R,w=(P*g+p*B)/R,d=(-P*p+g*B)/R,x=F-K,e=G-o,u=w-K,L=d-o;return x*x+e*e>u*u+L*L&&(F=w,G=d),{cx:F,cy:G,x01:-n,y01:-m,x11:F*(v/T-1),y11:G*(v/T-1)}}function vn(){var l=cn,h=yn,O=H(0),E=null,v=gn,A=mn,J=pn,r=null,q=ln(i);function i(){var n,m,a=+l.apply(this,arguments),s=+h.apply(this,arguments),f=v.apply(this,arguments)-an,c=A.apply(this,arguments)-an,K=un(c-f),o=c>f;if(r||(r=n=q()),s<a&&(m=s,s=a,a=m),!(s>y))r.moveTo(0,0);else if(K>on-y)r.moveTo(s*M(f),s*D(f)),r.arc(0,0,s,f,c,!o),a>y&&(r.moveTo(a*M(c),a*D(c)),r.arc(0,0,a,c,f,o));else{var p=f,g=c,R=f,T=c,P=K,B=K,F=J.apply(this,arguments)/2,G=F>y&&(E?+E.apply(this,arguments):j(a*a+s*s)),w=_(un(s-a)/2,+O.apply(this,arguments)),d=w,x=w,e,u;if(G>y){var L=sn(G/a*D(F)),z=sn(G/s*D(F));(P-=L*2)>y?(L*=o?1:-1,R+=L,T-=L):(P=0,R=T=(f+c)/2),(B-=z*2)>y?(z*=o?1:-1,p+=z,g-=z):(B=0,p=g=(f+c)/2)}var N=s*M(p),S=s*D(p),C=a*M(T),Q=a*D(T);if(w>y){var U=s*M(g),V=s*D(g),X=a*M(R),Y=a*D(R),I;if(K<rn)if(I=dn(N,S,X,Y,U,V,C,Q)){var Z=N-I[0],$=S-I[1],k=U-I[0],b=V-I[1],nn=1/D(fn((Z*k+$*b)/(j(Z*Z+$*$)*j(k*k+b*b)))/2),en=j(I[0]*I[0]+I[1]*I[1]);d=_(w,(a-en)/(nn-1)),x=_(w,(s-en)/(nn+1))}else d=x=0}B>y?x>y?(e=W(X,Y,N,S,s,x,o),u=W(U,V,C,Q,s,x,o),r.moveTo(e.cx+e.x01,e.cy+e.y01),x<w?r.arc(e.cx,e.cy,x,t(e.y01,e.x01),t(u.y01,u.x01),!o):(r.arc(e.cx,e.cy,x,t(e.y01,e.x01),t(e.y11,e.x11),!o),r.arc(0,0,s,t(e.cy+e.y11,e.cx+e.x11),t(u.cy+u.y11,u.cx+u.x11),!o),r.arc(u.cx,u.cy,x,t(u.y11,u.x11),t(u.y01,u.x01),!o))):(r.moveTo(N,S),r.arc(0,0,s,p,g,!o)):r.moveTo(N,S),!(a>y)||!(P>y)?r.lineTo(C,Q):d>y?(e=W(C,Q,U,V,a,-d,o),u=W(N,S,X,Y,a,-d,o),r.lineTo(e.cx+e.x01,e.cy+e.y01),d<w?r.arc(e.cx,e.cy,d,t(e.y01,e.x01),t(u.y01,u.x01),!o):(r.arc(e.cx,e.cy,d,t(e.y01,e.x01),t(e.y11,e.x11),!o),r.arc(0,0,a,t(e.cy+e.y11,e.cx+e.x11),t(u.cy+u.y11,u.cx+u.x11),o),r.arc(u.cx,u.cy,d,t(u.y11,u.x11),t(u.y01,u.x01),!o))):r.arc(0,0,a,T,R,o)}if(r.closePath(),n)return r=null,n+""||null}return i.centroid=function(){var n=(+l.apply(this,arguments)+ +h.apply(this,arguments))/2,m=(+v.apply(this,arguments)+ +A.apply(this,arguments))/2-rn/2;return[M(m)*n,D(m)*n]},i.innerRadius=function(n){return arguments.length?(l=typeof n=="function"?n:H(+n),i):l},i.outerRadius=function(n){return arguments.length?(h=typeof n=="function"?n:H(+n),i):h},i.cornerRadius=function(n){return arguments.length?(O=typeof n=="function"?n:H(+n),i):O},i.padRadius=function(n){return arguments.length?(E=n==null?null:typeof n=="function"?n:H(+n),i):E},i.startAngle=function(n){return arguments.length?(v=typeof n=="function"?n:H(+n),i):v},i.endAngle=function(n){return arguments.length?(A=typeof n=="function"?n:H(+n),i):A},i.padAngle=function(n){return arguments.length?(J=typeof n=="function"?n:H(+n),i):J},i.context=function(n){return arguments.length?(r=n??null,i):r},i}export{vn as a};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import"./percentages-BXMCSKIN-DmjnxD3b.js";import"./index-Cr2gUYn7.js";var e={paste:"Yapışdır",pasteAsPlaintext:"Düz mətn kimi yapışdırın",pasteCharts:"Diaqramları yapışdırın",selectAll:"Hamısını seç",multiSelect:"Seçimə element əlavə edin",moveCanvas:"Kanvası köçürün",cut:"Kəs",copy:"Kopyala",copyAsPng:"PNG olaraq panoya kopyala",copyAsSvg:"SVG olaraq panoya kopyala",copyText:"Mətn olaraq panoya kopyala",copySource:"",convertToCode:"",bringForward:"Önə daşı",sendToBack:"Geriyə göndərin",bringToFront:"Önə gətirin",sendBackward:"Geriyə göndərin",delete:"Sil",copyStyles:"Stilləri kopyalayın",pasteStyles:"Stilləri yapışdırın",stroke:"Strok rəngi",background:"Arxa fon",fill:"Doldur",strokeWidth:"Strok eni",strokeStyle:"Strok stili",strokeStyle_solid:"Solid",strokeStyle_dashed:"Kəsik",strokeStyle_dotted:"Nöqtəli",sloppiness:"Səliqəsizlik",opacity:"Şəffaflıq",textAlign:"Mətni uyğunlaşdır",edges:"Kənarlar",sharp:"Kəskin",round:"Dəyirmi",arrowheads:"Ox ucları",arrowhead_none:"Heç biri",arrowhead_arrow:"Ox",arrowhead_bar:"Çubuq",arrowhead_circle:"",arrowhead_circle_outline:"",arrowhead_triangle:"Üçbucaq",arrowhead_triangle_outline:"",arrowhead_diamond:"",arrowhead_diamond_outline:"",fontSize:"Şrift ölçüsü",fontFamily:"Şrift qrupu",addWatermark:'"Made with Excalidraw" əlavə et',handDrawn:"Əllə çəkilmiş",normal:"Normal",code:"Kod",small:"Kiçik",medium:"Orta",large:"Böyük",veryLarge:"Çox böyük",solid:"Solid",hachure:"Ştrix",zigzag:"Ziqzaq",crossHatch:"Çarpaz dəlik",thin:"İncə",bold:"Qalın",left:"Sol",center:"Mərkəz",right:"Sağ",extraBold:"Ekstra qalın",architect:"Memar",artist:"Rəssam",cartoonist:"Karikaturaçı",fileTitle:"Fayl adı",colorPicker:"Rəng seçən",canvasColors:"Kanvas üzərində istifadə olunur",canvasBackground:"Kanvas arxa fonu",drawingCanvas:"Kanvas çəkmək",layers:"Qatlar",actions:"Hərəkətlər",language:"Dil",liveCollaboration:"Canlı əməkdaşlıq...",duplicateSelection:"Dublikat",untitled:"Başlıqsız",name:"Ad",yourName:"Adınız",madeWithExcalidraw:"Excalidraw ilə hazırlanmışdır",group:"Qrup şəklində seçim",ungroup:"Qrupsuz seçim",collaborators:"",showGrid:"",addToLibrary:"",removeFromLibrary:"",libraryLoadingMessage:"",libraries:"",loadingScene:"",align:"",alignTop:"",alignBottom:"",alignLeft:"",alignRight:"",centerVertically:"",centerHorizontally:"",distributeHorizontally:"",distributeVertically:"",flipHorizontal:"",flipVertical:"",viewMode:"",share:"",showStroke:"",showBackground:"",toggleTheme:"",personalLib:"",excalidrawLib:"",decreaseFontSize:"",increaseFontSize:"",unbindText:"",bindText:"",createContainerFromText:"",link:{edit:"",editEmbed:"",create:"",createEmbed:"",label:"",labelEmbed:"",empty:""},lineEditor:{edit:"",exit:""},elementLock:{lock:"",unlock:"",lockAll:"",unlockAll:""},statusPublished:"",sidebarLock:"",selectAllElementsInFrame:"",removeAllElementsFromFrame:"",eyeDropper:"",textToDiagram:"",prompt:""},a={noItems:"",hint_emptyLibrary:"",hint_emptyPrivateLibrary:""},r={clearReset:"",exportJSON:"",exportImage:"",export:"",copyToClipboard:"",save:"",saveAs:"",load:"",getShareableLink:"",close:"",selectLanguage:"",scrollBackToContent:"",zoomIn:"",zoomOut:"",resetZoom:"",menu:"",done:"",edit:"",undo:"",redo:"",resetLibrary:"",createNewRoom:"",fullScreen:"",darkMode:"",lightMode:"",zenMode:"",objectsSnapMode:"",exitZenMode:"",cancel:"",clear:"",remove:"",embed:"",publishLibrary:"",submit:"",confirm:"",embeddableInteractionButton:""},o={clearReset:"",couldNotCreateShareableLink:"",couldNotCreateShareableLinkTooBig:"",couldNotLoadInvalidFile:"",importBackendFailed:"",cannotExportEmptyCanvas:"",couldNotCopyToClipboard:"",decryptFailed:"",uploadedSecurly:"",loadSceneOverridePrompt:"",collabStopOverridePrompt:"",errorAddingToLibrary:"",errorRemovingFromLibrary:"",confirmAddLibrary:"",imageDoesNotContainScene:"",cannotRestoreFromImage:"",invalidSceneUrl:"",resetLibrary:"",removeItemsFromsLibrary:"",invalidEncryptionKey:"",collabOfflineWarning:""},t={unsupportedFileType:"",imageInsertError:"",fileTooBig:"",svgImageInsertError:"",failedToFetchImage:"",invalidSVGString:"",cannotResolveCollabServer:"",importLibraryError:"",collabSaveFailed:"",collabSaveFailed_sizeExceeded:"",imageToolNotSupported:"",brave_measure_text_error:{line1:"",line2:"",line3:"",line4:""},libraryElementTypeError:{embeddable:"",iframe:"",image:""},asyncPasteFailedOnRead:"",asyncPasteFailedOnParse:"",copyToSystemClipboardFailed:""},i={selection:"",image:"",rectangle:"",diamond:"",ellipse:"",arrow:"",line:"",freedraw:"",text:"",library:"",lock:"",penMode:"",link:"",eraser:"",frame:"",magicframe:"",embeddable:"",laser:"",hand:"",extraTools:"",mermaidToExcalidraw:"",magicSettings:""},l={canvasActions:"",selectedShapeActions:"",shapes:""},n={canvasPanning:"",linearElement:"",freeDraw:"",text:"",embeddable:"",text_selected:"",text_editing:"",linearElementMulti:"",lockAngle:"",resize:"",resizeImage:"",rotate:"",lineEditor_info:"",lineEditor_pointSelected:"",lineEditor_nothingSelected:"",placeImage:"",publishLibrary:"",bindTextToElement:"",deepBoxSelect:"",eraserRevert:"",firefox_clipboard_write:"",disableSnapping:""},s={cannotShowPreview:"",canvasTooBig:"",canvasTooBigTip:""},d={headingMain:"",clearCanvasMessage:"",clearCanvasCaveat:"",trackedToSentry:"",openIssueMessage:"",sceneContent:""},u={desc_intro:"",desc_privacy:"",button_startSession:"",button_stopSession:"",desc_inProgressIntro:"",desc_shareLink:"",desc_exitSession:"",shareTitle:""},c={title:""},m={disk_title:"",disk_details:"",disk_button:"",link_title:"",link_details:"",link_button:"",excalidrawplus_description:"",excalidrawplus_button:"",excalidrawplus_exportError:""},p={blog:"",click:"",deepSelect:"",deepBoxSelect:"",curvedArrow:"",curvedLine:"",documentation:"",doubleClick:"",drag:"",editor:"",editLineArrowPoints:"",editText:"",github:"",howto:"",or:"",preventBinding:"",tools:"",shortcuts:"",textFinish:"",textNewLine:"",title:"",view:"",zoomToFit:"",zoomToSelection:"",toggleElementLock:"",movePageUpDown:"",movePageLeftRight:""},g={title:""},b={title:"",itemName:"",authorName:"",githubUsername:"",twitterUsername:"",libraryName:"",libraryDesc:"",website:"",placeholder:{authorName:"",libraryName:"",libraryDesc:"",githubHandle:"",twitterHandle:"",website:""},errors:{required:"",website:""},noteDescription:"",noteGuidelines:"",noteLicense:"",noteItems:"",atleastOneLibItem:"",republishWarning:""},y={title:"",content:""},x={resetLibrary:"",removeItemsFromLib:""},h={header:"",label:{withBackground:"",onlySelected:"",darkMode:"",embedScene:"",scale:"",padding:""},tooltip:{embedScene:""},title:{exportToPng:"",exportToSvg:"",copyPngToClipboard:""},button:{exportToPng:"",exportToSvg:"",copyPngToClipboard:""}},k={tooltip:"",link:""},S={angle:"",element:"",elements:"",height:"",scene:"",selected:"",storage:"",title:"",total:"",version:"",versionCopy:"",versionNotAvailable:"",width:""},v={addedToLibrary:"",copyStyles:"",copyToClipboard:"",copyToClipboardAsPng:"",fileSaved:"",fileSavedToFilename:"",canvas:"",selection:"",pasteAsSingleElement:"",unableToEmbed:"",unrecognizedLinkFormat:""},F={transparent:"",black:"",white:"",red:"",pink:"",grape:"",violet:"",gray:"",blue:"",cyan:"",teal:"",green:"",yellow:"",orange:"",bronze:""},w={app:{center_heading:"",center_heading_plus:"",menuHint:""},defaults:{menuHint:"",center_heading:"",toolbarHint:"",helpHint:""}},E={mostUsedCustomColors:"",colors:"",shades:"",hexCode:"",noShades:""},T={action:{exportToImage:{title:"",button:"",description:""},saveToDisk:{title:"",button:"",description:""},excalidrawPlus:{title:"",button:"",description:""}},modal:{loadFromFile:{title:"",button:"",description:""},shareableLink:{title:"",button:"",description:""}}},_={title:"",button:"",description:"",syntax:"",preview:""},L={labels:e,library:a,buttons:r,alerts:o,errors:t,toolBar:i,headings:l,hints:n,canvasError:s,errorSplash:d,roomDialog:u,errorDialog:c,exportDialog:m,helpDialog:p,clearCanvasDialog:g,publishDialog:b,publishSuccessDialog:y,confirmDialog:x,imageExportDialog:h,encrypted:k,stats:S,toast:v,colors:F,welcomeScreen:w,colorPicker:E,overwriteConfirm:T,mermaid:_};export{o as alerts,r as buttons,s as canvasError,g as clearCanvasDialog,E as colorPicker,F as colors,x as confirmDialog,L as default,k as encrypted,c as errorDialog,d as errorSplash,t as errors,m as exportDialog,l as headings,p as helpDialog,n as hints,h as imageExportDialog,e as labels,a as library,_ as mermaid,T as overwriteConfirm,b as publishDialog,y as publishSuccessDialog,u as roomDialog,S as stats,v as toast,i as toolBar,w as welcomeScreen};
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import"./percentages-BXMCSKIN-DmjnxD3b.js";import"./index-Cr2gUYn7.js";var u={paste:"Постави",pasteAsPlaintext:"Постави като обикновен текст",pasteCharts:"Постави графики",selectAll:"Маркирай всичко",multiSelect:"Добави елемент към селекция",moveCanvas:"Премести платно",cut:"Изрежи",copy:"Копирай",copyAsPng:"Копиране в клипборда",copyAsSvg:"Копирано в клипборда като SVG",copyText:"",copySource:"",convertToCode:"",bringForward:"Преместване напред",sendToBack:"Изнасяне назад",bringToFront:"Изнасяне отпред",sendBackward:"Изпрати отзад",delete:"Изтрий",copyStyles:"Копирайте стилове",pasteStyles:"Постави стилове",stroke:"Щрих",background:"Фон",fill:"Наситеност",strokeWidth:"Ширина на щриха",strokeStyle:"Стил на линия",strokeStyle_solid:"Плътен",strokeStyle_dashed:"Пунктир",strokeStyle_dotted:"Пунктирано",sloppiness:"Небрежност",opacity:"Прозрачност",textAlign:"Подравняване на текста",edges:"Крайща",sharp:"Остър",round:"Закръглено",arrowheads:"Стрелки",arrowhead_none:"Без",arrowhead_arrow:"Стрелка",arrowhead_bar:"Връх на стрелката",arrowhead_circle:"",arrowhead_circle_outline:"",arrowhead_triangle:"Триъгълник",arrowhead_triangle_outline:"",arrowhead_diamond:"",arrowhead_diamond_outline:"",fontSize:"Размер на шрифта",fontFamily:"Семейство шрифтове",addWatermark:'Добави "Направено с Excalidraw"',handDrawn:"Нарисувано на ръка",normal:"Нормален",code:"Код",small:"Малък",medium:"Среден",large:"Голям",veryLarge:"Много голям",solid:"Солиден",hachure:"Хералдика",zigzag:"Зигзаг",crossHatch:"Двойно-пресечено",thin:"Тънък",bold:"Ясно очертан",left:"Ляво",center:"Център",right:"Дясно",extraBold:"Много ясно очертан",architect:"Архитект",artist:"Художник",cartoonist:"Карикатурист",fileTitle:"Име на файл",colorPicker:"Избор на цвят",canvasColors:"Използван на платно",canvasBackground:"Фон на платно",drawingCanvas:"Платно за рисуване",layers:"Слоеве",actions:"Действия",language:"Език",liveCollaboration:"",duplicateSelection:"Дублирай",untitled:"Неозаглавено",name:"Име",yourName:"Вашето име",madeWithExcalidraw:"Направено с Excalidraw",group:"Групирай селекцията",ungroup:"Спри групирането на селекцията",collaborators:"Сътрудници",showGrid:"Показване на мрежа",addToLibrary:"Добавяне към библиотеката",removeFromLibrary:"Премахване от библиотеката",libraryLoadingMessage:"Зареждане на библиотеката…",libraries:"Разглеждане на библиотеките",loadingScene:"Зареждане на сцена…",align:"Подравняване",alignTop:"Подравняване отгоре",alignBottom:"Подравняване отдолу",alignLeft:"Подравняване отляво",alignRight:"Подравняване отдясно",centerVertically:"Центрирай вертикално",centerHorizontally:"Центрирай хоризонтално",distributeHorizontally:"Разпредели хоризонтално",distributeVertically:"Разпредели вертикално",flipHorizontal:"Хоризонтално обръщане",flipVertical:"Вертикално обръщане",viewMode:"Изглед",share:"Сподели",showStroke:"",showBackground:"",toggleTheme:"Включи тема",personalLib:"Лична Библиотека",excalidrawLib:"Excalidraw Библиотека",decreaseFontSize:"Намали размера на шрифта",increaseFontSize:"Увеличи размера на шрифта",unbindText:"",bindText:"",createContainerFromText:"",link:{edit:"Редактирай линк",editEmbed:"",create:"",createEmbed:"",label:"Линк",labelEmbed:"",empty:""},lineEditor:{edit:"",exit:""},elementLock:{lock:"Заключи",unlock:"Отключи",lockAll:"Заключи всички",unlockAll:"Отключи всички"},statusPublished:"Публикувани",sidebarLock:"",selectAllElementsInFrame:"",removeAllElementsFromFrame:"",eyeDropper:"Избери цвят от платното",textToDiagram:"",prompt:""},e={noItems:"Няма добавени неща все още...",hint_emptyLibrary:"",hint_emptyPrivateLibrary:""},E={clearReset:"Нулиране на платно",exportJSON:"",exportImage:"",export:"Запази на...",copyToClipboard:"Копиране в клипборда",save:"Запази към текущ файл",saveAs:"Запиши като",load:"Отвори",getShareableLink:"Получаване на връзка за споделяне",close:"Затвори",selectLanguage:"Избор на език",scrollBackToContent:"Превъртете обратно към съдържанието",zoomIn:"Приближаване",zoomOut:"Отдалечаване",resetZoom:"Стандартен мащаб",menu:"Меню",done:"Завършено",edit:"Редактиране",undo:"Отмяна",redo:"Повтори",resetLibrary:"Нулиране на библиотеката",createNewRoom:"Създай нова стая",fullScreen:"На цял екран",darkMode:"Тъмен режим",lightMode:"Светъл режим",zenMode:"Режим Zen",objectsSnapMode:"",exitZenMode:"Спиране на Zen режим",cancel:"Отмени",clear:"Изчисти",remove:"Премахване",embed:"",publishLibrary:"Публикувай",submit:"Изпрати",confirm:"Потвърждаване",embeddableInteractionButton:""},D={clearReset:"Това ще изчисти цялото платно. Сигурни ли сте?",couldNotCreateShareableLink:"Връзката не може да бъде създадена.",couldNotCreateShareableLinkTooBig:"Не може да се създаде връзка за споделяне: сцената е твърде голяма",couldNotLoadInvalidFile:"Невалиден файл не може да се зареди",importBackendFailed:"Импортирането от бекенд не беше успешно.",cannotExportEmptyCanvas:"Не може да се експортира празно платно.",couldNotCopyToClipboard:"Не можем да копираме в клипбоарда.",decryptFailed:"Данните не можаха да се дешифрират.",uploadedSecurly:"Качването е защитено с криптиране от край до край, което означава, че сървърът Excalidraw и трети страни не могат да четат съдържанието.",loadSceneOverridePrompt:"Зареждането на външна рисунка ще презапише настоящото ви съдържание. Желаете ли да продължите?",collabStopOverridePrompt:`Прекратяването на сесията ще презапише предишната, локално запазена, рисунка. Сигурни ли сте?
|
|
2
|
+
|
|
3
|
+
(Ако искате да продължите с локалната рисунка, просто затворете таба на браузъра.)`,errorAddingToLibrary:"Не можем да заредим от библиотеката",errorRemovingFromLibrary:"Не можем да премахнем елемент от библиотеката",confirmAddLibrary:"Ще се добавят {{numShapes}} фигура(и) във вашата библиотека. Сигурни ли сте?",imageDoesNotContainScene:"",cannotRestoreFromImage:"Не може да бъде възстановена сцена от този файл",invalidSceneUrl:"",resetLibrary:"",removeItemsFromsLibrary:"Изтрий {{count}} елемент(а) от библиотеката?",invalidEncryptionKey:"",collabOfflineWarning:""},a={unsupportedFileType:"Този файлов формат не се поддържа.",imageInsertError:"",fileTooBig:"Файлът е твърде голям. Максималния допустим размер е {{maxSize}}.",svgImageInsertError:"",failedToFetchImage:"",invalidSVGString:"Невалиден SVG.",cannotResolveCollabServer:"",importLibraryError:"Не можем да заредим библиотеката",collabSaveFailed:"",collabSaveFailed_sizeExceeded:"",imageToolNotSupported:"",brave_measure_text_error:{line1:"",line2:"",line3:"Силно препоръчваме да изключите тази настройка. Можете да следвате <link>тези стъпки</link> за това как да го направите.",line4:""},libraryElementTypeError:{embeddable:"",iframe:"",image:""},asyncPasteFailedOnRead:"",asyncPasteFailedOnParse:"",copyToSystemClipboardFailed:""},o={selection:"Селекция",image:"Вмъкване на изображение",rectangle:"Правоъгълник",diamond:"Диамант",ellipse:"Елипс",arrow:"Стрелка",line:"Линия",freedraw:"Рисуване",text:"Текст",library:"Библиотека",lock:"Поддържайте избрания инструмент активен след рисуване",penMode:"",link:"",eraser:"Гума",frame:"",magicframe:"",embeddable:"",laser:"",hand:"",extraTools:"Още инструменти",mermaidToExcalidraw:"",magicSettings:""},r={canvasActions:"Действия по платното",selectedShapeActions:"Избрани действия",shapes:"Фигури"},t={canvasPanning:"",linearElement:"Кликнете, за да стартирате няколко точки, плъзнете за една линия",freeDraw:"Натиснете и влачете, пуснете като сте готови",text:"Подсказка: Можете също да добавите текст като натиснете някъде два път с инструмента за селекция",embeddable:"",text_selected:"",text_editing:"",linearElementMulti:"Кликнете върху последната точка или натиснете Escape или Enter, за да завършите",lockAngle:"Можете да ограничите ъгъла, като задържите SHIFT",resize:`Може да ограничите при преоразмеряване като задържите SHIFT,
|
|
4
|
+
задръжте ALT за преоразмерите през центъра`,resizeImage:"",rotate:"Можете да ограничите ъглите, като държите SHIFT, докато се въртите",lineEditor_info:"",lineEditor_pointSelected:"Натиснете Delete за да изтриете точка(и), CtrlOrCmd+D за дуплициране, или извлачете за да преместите",lineEditor_nothingSelected:"",placeImage:"",publishLibrary:"",bindTextToElement:"Натиснете Enter, за да добавите",deepBoxSelect:"",eraserRevert:"",firefox_clipboard_write:"",disableSnapping:""},i={cannotShowPreview:"Невъзможност за показване на preview",canvasTooBig:"Платното е твърде голямо.",canvasTooBigTip:"Подсказка: пробвайте да приближите далечните елементи по-близко."},A={headingMain:"Среща грешка. Опитайте <button>презареждане на страницата.</button>",clearCanvasMessage:"Ако презареждането не работи, опитайте <button>изчистване на платното.</button>",clearCanvasCaveat:" Това ще доведе до загуба на работа ",trackedToSentry:"Грешката с идентификатор {{eventId}} беше проследен в нашата система.",openIssueMessage:"Бяхме много предпазливи да не включите информацията за вашата сцена при грешката. Ако сцената ви не е частна, моля, помислете за последващи действия на нашата <button>тракер за грешки.</button> Моля, включете информация по-долу, като я копирате и добавите в GitHub.",sceneContent:"Съдържание на сцената:"},l={desc_intro:"Можете да поканите хора на текущата си сцена да си сътрудничат с вас.",desc_privacy:"Не се притеснявайте, сесията използва криптиране от край до край, така че каквото нарисувате ще остане частно. Дори нашият сървър няма да може да види какво предлагате.",button_startSession:"Стартирайте сесията",button_stopSession:"Стоп на сесията",desc_inProgressIntro:"Сесията за сътрудничество на живо е в ход.",desc_shareLink:"Споделете тази връзка с всеки, с когото искате да си сътрудничите:",desc_exitSession:"Спирането на сесията ще ви изключи от стаята, но ще можете да продължите да работите със сцената, локално. Имайте предвид, че това няма да засегне други хора и те все още ще могат да си сътрудничат с тяхната версия.",shareTitle:""},n={title:"Грешка"},F={disk_title:"",disk_details:"",disk_button:"",link_title:"",link_details:"",link_button:"",excalidrawplus_description:"",excalidrawplus_button:"Експорт",excalidrawplus_exportError:""},s={blog:"Прочетете нашия блог",click:"клик",deepSelect:"",deepBoxSelect:"",curvedArrow:"Извита стрелка",curvedLine:"Извита линия",documentation:"Документация",doubleClick:"двойно-щракване",drag:"плъзнете",editor:"Редактор",editLineArrowPoints:"",editText:"",github:"Намерихте проблем? Изпратете",howto:"Следвайте нашите ръководства",or:"или",preventBinding:"Спри прилепяне на стрелките",tools:"Инструменти",shortcuts:"Клавиши за бърз достъп",textFinish:"Завърши редактиране (текстов редактор)",textNewLine:"Добави нова линия (текстов редактор)",title:"Помощ",view:"Преглед",zoomToFit:"Приближи докато се виждат всички елементи",zoomToSelection:"Приближи селекцията",toggleElementLock:"Заключи/Отключи селекция",movePageUpDown:"Премести страница нагоре/надолу",movePageLeftRight:"Премести страница наляво/надясно"},B={title:"Изчисти платното"},d={title:"Публикувай библиотека",itemName:"Име",authorName:"Авторско име",githubUsername:"GitHub потребителско име",twitterUsername:"Twitter потребителско име",libraryName:"Име на библиотеката",libraryDesc:"Описание на библиотеката",website:"Уебсайт",placeholder:{authorName:"Името или потребителското Ви име",libraryName:"Име на библиотеката Ви",libraryDesc:"Описание на библиотеката ви, за да помогнете на хората да разберат приложенията ѝ",githubHandle:"",twitterHandle:"",website:""},errors:{required:"Задължително",website:"Въведете валиден URL адрес"},noteDescription:"",noteGuidelines:"",noteLicense:"",noteItems:"",atleastOneLibItem:"",republishWarning:""},c={title:"",content:""},C={resetLibrary:"Нулирай библиотека",removeItemsFromLib:""},m={header:"",label:{withBackground:"Фон",onlySelected:"Само избраното",darkMode:"Тъмен режим",embedScene:"",scale:"",padding:""},tooltip:{embedScene:""},title:{exportToPng:"Изнасяне в PNG",exportToSvg:"Изнасяне в SVG",copyPngToClipboard:"Копирай PNG в клипборда"},button:{exportToPng:"PNG",exportToSvg:"SVG",copyPngToClipboard:"Копиране в клипборда"}},p={tooltip:"Вашите рисунки са криптирани от край до край, така че сървърите на Excalidraw няма да могат да ги виждат.",link:""},b={angle:"Ъгъл",element:"Елемент",elements:"Елементи",height:"Височина",scene:"Сцена",selected:"Селектирано",storage:"Съхранение на данни",title:"Статистика за хакери",total:"Общо",version:"Версия",versionCopy:"Настисни за да копираш",versionNotAvailable:"Версията не е налична",width:"Широчина"},g={addedToLibrary:"Добавена към библиотеката",copyStyles:"Копирани стилове.",copyToClipboard:"Копирано в клипборда.",copyToClipboardAsPng:`Копира {{exportSelection}} в клипборда като PNG
|
|
5
|
+
({{exportColorScheme}})`,fileSaved:"Файлът е запазен.",fileSavedToFilename:"Запазен към {filename}",canvas:"платно",selection:"селекция",pasteAsSingleElement:"",unableToEmbed:"",unrecognizedLinkFormat:""},h={transparent:"Прозрачен",black:"Черен",white:"Бял",red:"Червен",pink:"Розов",grape:"Грозде",violet:"Виолетово",gray:"Сив",blue:"Син",cyan:"Синьозелено",teal:"Тъмно синьо-зелено",green:"Зелено",yellow:"Жълто",orange:"Оранжево",bronze:"Бронзово"},y={app:{center_heading:"Всичките Ви данни са запазени локално в браузъра Ви.",center_heading_plus:"",menuHint:"Експорт, предпочитания, езици, ..."},defaults:{menuHint:"Експорт, предпочитания, и още...",center_heading:"Диаграми. Направени. Просто.",toolbarHint:"Изберете инструмент & Започнете да рисувате!",helpHint:"Преки пътища & помощ"}},S={mostUsedCustomColors:"Най-често използвани цветове",colors:"Цветове",shades:"Нюанси",hexCode:"Шестнадесетичен код",noShades:""},v={action:{exportToImage:{title:"Изнеси като изображение",button:"Изнеси като изображение",description:""},saveToDisk:{title:"Запази към диск",button:"Запази към диск",description:""},excalidrawPlus:{title:"Excalidraw+",button:"Експортирай към Excalidraw+",description:"Запази сцената към Excalidraw+ работното място."}},modal:{loadFromFile:{title:"Зареди от файл",button:"Зареди от файл",description:""},shareableLink:{title:"Зареди от линк",button:"Замени моето съдържание",description:""}}},w={title:"",button:"",description:"",syntax:"",preview:""},T={labels:u,library:e,buttons:E,alerts:D,errors:a,toolBar:o,headings:r,hints:t,canvasError:i,errorSplash:A,roomDialog:l,errorDialog:n,exportDialog:F,helpDialog:s,clearCanvasDialog:B,publishDialog:d,publishSuccessDialog:c,confirmDialog:C,imageExportDialog:m,encrypted:p,stats:b,toast:g,colors:h,welcomeScreen:y,colorPicker:S,overwriteConfirm:v,mermaid:w};export{D as alerts,E as buttons,i as canvasError,B as clearCanvasDialog,S as colorPicker,h as colors,C as confirmDialog,T as default,p as encrypted,n as errorDialog,A as errorSplash,a as errors,F as exportDialog,r as headings,s as helpDialog,t as hints,m as imageExportDialog,u as labels,e as library,w as mermaid,v as overwriteConfirm,d as publishDialog,c as publishSuccessDialog,l as roomDialog,b as stats,g as toast,o as toolBar,y as welcomeScreen};
|