@promptbook/components 0.103.0-21 → 0.103.0-23
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/README.md +0 -1
- package/esm/index.es.js +269 -34
- package/esm/index.es.js.map +1 -1
- package/esm/typings/src/_packages/components.index.d.ts +6 -4
- package/esm/typings/src/_packages/types.index.d.ts +2 -0
- package/esm/typings/src/book-components/BookEditor/BookEditor.d.ts +18 -1
- package/esm/typings/src/book-components/BookEditor/BookEditorActionbar.d.ts +3 -0
- package/esm/typings/src/book-components/Chat/MarkdownContent/MarkdownContent.d.ts +7 -4
- package/esm/typings/src/book-components/Qr/BrandedQrCode.d.ts +18 -0
- package/esm/typings/src/book-components/Qr/GenericQrCode.d.ts +10 -0
- package/esm/typings/src/book-components/Qr/PromptbookQrCode.d.ts +18 -0
- package/esm/typings/src/book-components/Qr/useQrCode.d.ts +15 -0
- package/esm/typings/src/book-components/icons/CloseIcon.d.ts +4 -8
- package/esm/typings/src/book-components/icons/ExitFullscreenIcon.d.ts +7 -0
- package/esm/typings/src/book-components/icons/FullscreenIcon.d.ts +7 -0
- package/esm/typings/src/version.d.ts +1 -1
- package/package.json +5 -4
- package/umd/index.umd.js +275 -39
- package/umd/index.umd.js.map +1 -1
- package/esm/typings/src/book-components/BookEditor/config.d.ts +0 -11
package/umd/index.umd.js
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
(function (global, factory) {
|
|
2
|
-
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('react/jsx-runtime'), require('react'), require('spacetrim'), require('react-dom'), require('path'), require('crypto'), require('@monaco-editor/react'), require('rxjs'), require('waitasecond'), require('crypto-js/enc-hex'), require('crypto-js/sha256'), require('crypto-js'), require('mime-types'), require('papaparse'), require('moment'), require('colors'), require('highlight.js'), require('katex'), require('showdown')) :
|
|
3
|
-
typeof define === 'function' && define.amd ? define(['exports', 'react/jsx-runtime', 'react', 'spacetrim', 'react-dom', 'path', 'crypto', '@monaco-editor/react', 'rxjs', 'waitasecond', 'crypto-js/enc-hex', 'crypto-js/sha256', 'crypto-js', 'mime-types', 'papaparse', 'moment', 'colors', 'highlight.js', 'katex', 'showdown'], factory) :
|
|
4
|
-
(global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global["promptbook-components"] = {}, global.jsxRuntime, global.react, global.spaceTrim, global.reactDom, global.path, global.crypto, global.Editor, global.rxjs, global.waitasecond, global.hexEncoder, global.sha256, global.cryptoJs, global.mimeTypes, global.papaparse, null, null, global.hljs, global.katex, global.showdown));
|
|
5
|
-
})(this, (function (exports, jsxRuntime, react, spaceTrim, reactDom, path, crypto, Editor, rxjs, waitasecond, hexEncoder, sha256, cryptoJs, mimeTypes, papaparse, moment, colors, hljs, katex, showdown) { 'use strict';
|
|
2
|
+
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('react/jsx-runtime'), require('react'), require('spacetrim'), require('react-dom'), require('path'), require('crypto'), require('@monaco-editor/react'), require('rxjs'), require('waitasecond'), require('crypto-js/enc-hex'), require('crypto-js/sha256'), require('crypto-js'), require('mime-types'), require('papaparse'), require('moment'), require('colors'), require('highlight.js'), require('katex'), require('showdown'), require('qrcode')) :
|
|
3
|
+
typeof define === 'function' && define.amd ? define(['exports', 'react/jsx-runtime', 'react', 'spacetrim', 'react-dom', 'path', 'crypto', '@monaco-editor/react', 'rxjs', 'waitasecond', 'crypto-js/enc-hex', 'crypto-js/sha256', 'crypto-js', 'mime-types', 'papaparse', 'moment', 'colors', 'highlight.js', 'katex', 'showdown', 'qrcode'], factory) :
|
|
4
|
+
(global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global["promptbook-components"] = {}, global.jsxRuntime, global.react, global.spaceTrim, global.reactDom, global.path, global.crypto, global.Editor, global.rxjs, global.waitasecond, global.hexEncoder, global.sha256, global.cryptoJs, global.mimeTypes, global.papaparse, null, null, global.hljs, global.katex, global.showdown, global.QRCode));
|
|
5
|
+
})(this, (function (exports, jsxRuntime, react, spaceTrim, reactDom, path, crypto, Editor, rxjs, waitasecond, hexEncoder, sha256, cryptoJs, mimeTypes, papaparse, moment, colors, hljs, katex, showdown, QRCode) { 'use strict';
|
|
6
6
|
|
|
7
7
|
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
8
8
|
|
|
@@ -12,6 +12,7 @@
|
|
|
12
12
|
var sha256__default = /*#__PURE__*/_interopDefaultLegacy(sha256);
|
|
13
13
|
var hljs__default = /*#__PURE__*/_interopDefaultLegacy(hljs);
|
|
14
14
|
var katex__default = /*#__PURE__*/_interopDefaultLegacy(katex);
|
|
15
|
+
var QRCode__default = /*#__PURE__*/_interopDefaultLegacy(QRCode);
|
|
15
16
|
|
|
16
17
|
// ⚠️ WARNING: This code has been generated so that any manual changes will be overwritten
|
|
17
18
|
/**
|
|
@@ -27,7 +28,7 @@
|
|
|
27
28
|
* @generated
|
|
28
29
|
* @see https://github.com/webgptorg/promptbook
|
|
29
30
|
*/
|
|
30
|
-
const PROMPTBOOK_ENGINE_VERSION = '0.103.0-
|
|
31
|
+
const PROMPTBOOK_ENGINE_VERSION = '0.103.0-23';
|
|
31
32
|
/**
|
|
32
33
|
* TODO: string_promptbook_version should be constrained to the all versions of Promptbook engine
|
|
33
34
|
* Note: [💞] Ignore a discrepancy between file name and entity name
|
|
@@ -5697,13 +5698,13 @@
|
|
|
5697
5698
|
`)));
|
|
5698
5699
|
// <- Note: Not using book`...` notation to avoid strange error in jest unit tests `TypeError: (0 , book_notation_1.book) is not a function`
|
|
5699
5700
|
|
|
5700
|
-
var css_248z$4 = ".BookEditor-module_BookEditor__s-0PU{width:100%}.BookEditor-module_bookEditorContainer__wLMwM{box-sizing:border-box;height:100%;padding:10px 25px 0;position:relative;width:100%}.BookEditor-module_bookEditorContainer__wLMwM.BookEditor-module_isVerbose__VQ6iL{background-color:rgba(0,0,0,.05);outline:1px dotted rgba(0,0,0,.5)}.BookEditor-module_isVerbose__VQ6iL{outline:2px dotted #ff7526}.BookEditor-module_bookEditorWrapper__twppD{background-color:#fff;border:1px solid rgba(209,213,219,.8);border-radius:1rem;box-shadow:0 1px 2px 0 rgba(0,0,0,.05);overflow:hidden;padding-top:10px;transition:box-shadow .2s ease-in-out}.BookEditor-module_isVerbose__VQ6iL .BookEditor-module_bookEditorWrapper__twppD{overflow:visible}.BookEditor-module_bookEditorWrapper__twppD:hover{box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06)}.BookEditor-module_bookEditorWrapper__twppD.BookEditor-module_isBorderRadiusDisabled__h1I3v{border-radius:0}.BookEditor-module_dropOverlay__xWWoX{align-items:center;background-color:rgba(0,0,0,.5);bottom:0;color:#fff;display:flex;font-size:1.5rem;justify-content:center;left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:100}.BookEditor-module_bookEditorContainer__wLMwM .view-line{border-bottom:1px solid #eee}.BookEditor-module_bookEditorActionbar__KW6dc{position:absolute;right:55px;top:10px;z-index:100}.BookEditor-module_button__hS390{align-items:center;background-color:#fff;border:1px solid #d1d5db;border-radius:.375rem;box-shadow:0 1px 2px 0 rgba(0,0,0,.05);color:#374151;cursor:pointer;display:inline-flex;gap:.5rem;padding:.5rem 1rem;transition:all .2s ease-in-out}.BookEditor-module_button__hS390:hover{background-color:#f9fafb;border-color:#b7bcce;box-shadow:0 1px 3px 0 rgba(0,0,0,.1),0 1px 2px 0 rgba(0,0,0,.06)}\n/*# sourceMappingURL=data:application/json;base64,
|
|
5701
|
-
var styles$3 = {"BookEditor":"BookEditor-module_BookEditor__s-0PU","bookEditorContainer":"BookEditor-module_bookEditorContainer__wLMwM","isVerbose":"BookEditor-module_isVerbose__VQ6iL","bookEditorWrapper":"BookEditor-module_bookEditorWrapper__twppD","isBorderRadiusDisabled":"BookEditor-module_isBorderRadiusDisabled__h1I3v","dropOverlay":"BookEditor-module_dropOverlay__xWWoX","bookEditorActionbar":"BookEditor-module_bookEditorActionbar__KW6dc","button":"BookEditor-module_button__hS390"};
|
|
5701
|
+
var css_248z$4 = ".BookEditor-module_BookEditor__s-0PU{width:100%}.BookEditor-module_bookEditorContainer__wLMwM{box-sizing:border-box;height:100%;padding:10px 25px 0;position:relative;width:100%}.BookEditor-module_bookEditorContainer__wLMwM.BookEditor-module_isVerbose__VQ6iL{background-color:rgba(0,0,0,.05);outline:1px dotted rgba(0,0,0,.5)}.BookEditor-module_isVerbose__VQ6iL{outline:2px dotted #ff7526}.BookEditor-module_bookEditorWrapper__twppD{background-color:#fff;border:1px solid rgba(209,213,219,.8);border-radius:1rem;box-shadow:0 1px 2px 0 rgba(0,0,0,.05);overflow:hidden;padding-top:10px;transition:box-shadow .2s ease-in-out}.BookEditor-module_isVerbose__VQ6iL .BookEditor-module_bookEditorWrapper__twppD{overflow:visible}.BookEditor-module_bookEditorWrapper__twppD:hover{box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06)}.BookEditor-module_bookEditorWrapper__twppD.BookEditor-module_isBorderRadiusDisabled__h1I3v{border-radius:0}.BookEditor-module_dropOverlay__xWWoX{align-items:center;background-color:rgba(0,0,0,.5);bottom:0;color:#fff;display:flex;font-size:1.5rem;justify-content:center;left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:100}.BookEditor-module_bookEditorContainer__wLMwM .view-line{border-bottom:1px solid #eee}.BookEditor-module_bookEditorActionbar__KW6dc{position:absolute;right:55px;top:10px;z-index:100}.BookEditor-module_fullscreen__rktsl{border-radius:0!important;height:100vh!important;left:0;padding-top:50px!important;position:fixed;top:0;width:100vw;z-index:9999}.BookEditor-module_button__hS390{align-items:center;background-color:#fff;border:1px solid #d1d5db;border-radius:.375rem;box-shadow:0 1px 2px 0 rgba(0,0,0,.05);color:#374151;cursor:pointer;display:inline-flex;gap:.5rem;padding:.5rem 1rem;transition:all .2s ease-in-out}.BookEditor-module_button__hS390:hover{background-color:#f9fafb;border-color:#b7bcce;box-shadow:0 1px 3px 0 rgba(0,0,0,.1),0 1px 2px 0 rgba(0,0,0,.06)}\n/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkJvb2tFZGl0b3IubW9kdWxlLmNzcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxxQ0FFSSxVQUNKLENBRUEsOENBS0kscUJBQXNCLENBSHRCLFdBQVksQ0FFWixtQkFBb0IsQ0FEcEIsaUJBQWtCLENBRmxCLFVBS0osQ0FFQSxpRkFFSSxnQ0FBcUMsQ0FDckMsaUNBRUosQ0FFQSxvQ0FDSSwwQkFDSixDQUVBLDRDQUtJLHFCQUF1QixDQUR2QixxQ0FBMEMsQ0FGMUMsa0JBQW1CLENBSW5CLHNDQUEyQyxDQUwzQyxlQUFnQixDQUVoQixnQkFBaUIsQ0FJakIscUNBQ0osQ0FDQSxnRkFFSSxnQkFFSixDQUVBLGtEQUNJLHVFQUNKLENBVUEsNEZBQ0ksZUFDSixDQUVBLHNDQVNJLGtCQUFtQixDQUhuQiwrQkFBb0MsQ0FEcEMsUUFBUyxDQUVULFVBQVksQ0FDWixZQUFhLENBR2IsZ0JBQWlCLENBRGpCLHNCQUF1QixDQVB2QixNQUFPLENBVVAsbUJBQW9CLENBWnBCLGlCQUFrQixDQUdsQixPQUFRLENBRlIsS0FBTSxDQVVOLFdBRUosQ0FFQSx5REFDSSw0QkFDSixDQUVBLDhDQUNJLGlCQUFrQixDQUVsQixVQUFXLENBRFgsUUFBUyxDQUVULFdBQ0osQ0FFQSxxQ0FPSSx5QkFBMkIsQ0FGM0Isc0JBQXdCLENBRnhCLE1BQU8sQ0FLUCwwQkFBNEIsQ0FQNUIsY0FBZSxDQUNmLEtBQU0sQ0FFTixXQUFZLENBRVosWUFHSixDQUVBLGlDQU9JLGtCQUFtQixDQU5uQixxQkFBc0IsQ0FDdEIsd0JBQXlCLENBQ3pCLHFCQUF1QixDQU92QixzQ0FBMkMsQ0FEM0MsYUFBYyxDQUpkLGNBQWUsQ0FDZixtQkFBb0IsQ0FFcEIsU0FBVyxDQUpYLGtCQUFvQixDQU9wQiw4QkFDSixDQUVBLHVDQUNJLHdCQUF5QixDQUN6QixvQkFBcUIsQ0FDckIsaUVBQ0oiLCJmaWxlIjoiQm9va0VkaXRvci5tb2R1bGUuY3NzIiwic291cmNlc0NvbnRlbnQiOlsiLkJvb2tFZGl0b3Ige1xuICAgIC8qIGhlaWdodDogNDUwcHg7ICovXG4gICAgd2lkdGg6IDEwMCU7XG59XG5cbi5ib29rRWRpdG9yQ29udGFpbmVyIHtcbiAgICB3aWR0aDogMTAwJTtcbiAgICBoZWlnaHQ6IDEwMCU7XG4gICAgcG9zaXRpb246IHJlbGF0aXZlO1xuICAgIHBhZGRpbmc6IDEwcHggMjVweCAwO1xuICAgIGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG59XG5cbi5ib29rRWRpdG9yQ29udGFpbmVyLmlzVmVyYm9zZSB7XG4gICAgLyoqL1xuICAgIGJhY2tncm91bmQtY29sb3I6IHJnYmEoMCwgMCwgMCwgMC4wNSk7XG4gICAgb3V0bGluZTogMXB4IGRvdHRlZCByZ2JhKDAsIDAsIDAsIDAuNSk7XG4gICAgLyoqL1xufVxuXG4uaXNWZXJib3NlIHtcbiAgICBvdXRsaW5lOiAycHggZG90dGVkIHJnYigyNTUgMTE3IDM4KTtcbn1cblxuLmJvb2tFZGl0b3JXcmFwcGVyIHtcbiAgICBvdmVyZmxvdzogaGlkZGVuO1xuICAgIGJvcmRlci1yYWRpdXM6IDFyZW07XG4gICAgcGFkZGluZy10b3A6IDEwcHg7XG4gICAgYm9yZGVyOiAxcHggc29saWQgcmdiYSgyMDksIDIxMywgMjE5LCAwLjgpO1xuICAgIGJhY2tncm91bmQtY29sb3I6IHdoaXRlO1xuICAgIGJveC1zaGFkb3c6IDAgMXB4IDJweCAwIHJnYmEoMCwgMCwgMCwgMC4wNSk7XG4gICAgdHJhbnNpdGlvbjogYm94LXNoYWRvdyAwLjJzIGVhc2UtaW4tb3V0O1xufVxuLmlzVmVyYm9zZSAuYm9va0VkaXRvcldyYXBwZXIge1xuICAgIC8qKi9cbiAgICBvdmVyZmxvdzogdmlzaWJsZTtcbiAgICAvKiovXG59XG5cbi5ib29rRWRpdG9yV3JhcHBlcjpob3ZlciB7XG4gICAgYm94LXNoYWRvdzogMCA0cHggNnB4IC0xcHggcmdiYSgwLCAwLCAwLCAwLjEpLCAwIDJweCA0cHggLTFweCByZ2JhKDAsIDAsIDAsIDAuMDYpO1xufVxuXG4uYm9va0VkaXRvcldyYXBwZXI6Zm9jdXMtd2l0aGluIHtcbiAgICAvKlxuICAgIG91dGxpbmU6IDJweCBzb2xpZCB0cmFuc3BhcmVudDtcbiAgICBvdXRsaW5lLW9mZnNldDogMnB4O1xuICAgIGJveC1zaGFkb3c6IDAgMCAwIDNweCByZ2JhKDk5LCAxMDIsIDI0MSwgMC40KTtcbiAgICAqL1xufVxuXG4uYm9va0VkaXRvcldyYXBwZXIuaXNCb3JkZXJSYWRpdXNEaXNhYmxlZCB7XG4gICAgYm9yZGVyLXJhZGl1czogMDtcbn1cblxuLmRyb3BPdmVybGF5IHtcbiAgICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gICAgdG9wOiAwO1xuICAgIGxlZnQ6IDA7XG4gICAgcmlnaHQ6IDA7XG4gICAgYm90dG9tOiAwO1xuICAgIGJhY2tncm91bmQtY29sb3I6IHJnYmEoMCwgMCwgMCwgMC41KTtcbiAgICBjb2xvcjogd2hpdGU7XG4gICAgZGlzcGxheTogZmxleDtcbiAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuICAgIGZvbnQtc2l6ZTogMS41cmVtO1xuICAgIHotaW5kZXg6IDEwMDtcbiAgICBwb2ludGVyLWV2ZW50czogbm9uZTtcbn1cblxuLmJvb2tFZGl0b3JDb250YWluZXIgOmdsb2JhbCgudmlldy1saW5lKSB7XG4gICAgYm9yZGVyLWJvdHRvbTogMXB4IHNvbGlkICNlZWU7XG59XG5cbi5ib29rRWRpdG9yQWN0aW9uYmFyIHtcbiAgICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gICAgdG9wOiAxMHB4O1xuICAgIHJpZ2h0OiA1NXB4O1xuICAgIHotaW5kZXg6IDEwMDtcbn1cblxuLmZ1bGxzY3JlZW4ge1xuICAgIHBvc2l0aW9uOiBmaXhlZDtcbiAgICB0b3A6IDA7XG4gICAgbGVmdDogMDtcbiAgICB3aWR0aDogMTAwdnc7XG4gICAgaGVpZ2h0OiAxMDB2aCAhaW1wb3J0YW50O1xuICAgIHotaW5kZXg6IDk5OTk7XG4gICAgYm9yZGVyLXJhZGl1czogMCAhaW1wb3J0YW50O1xuICAgIHBhZGRpbmctdG9wOiA1MHB4ICFpbXBvcnRhbnQ7XG59XG5cbi5idXR0b24ge1xuICAgIGJhY2tncm91bmQtY29sb3I6ICNmZmY7XG4gICAgYm9yZGVyOiAxcHggc29saWQgI2QxZDVkYjtcbiAgICBib3JkZXItcmFkaXVzOiAwLjM3NXJlbTtcbiAgICBwYWRkaW5nOiAwLjVyZW0gMXJlbTtcbiAgICBjdXJzb3I6IHBvaW50ZXI7XG4gICAgZGlzcGxheTogaW5saW5lLWZsZXg7XG4gICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICBnYXA6IDAuNXJlbTtcbiAgICBjb2xvcjogIzM3NDE1MTtcbiAgICBib3gtc2hhZG93OiAwIDFweCAycHggMCByZ2JhKDAsIDAsIDAsIDAuMDUpO1xuICAgIHRyYW5zaXRpb246IGFsbCAwLjJzIGVhc2UtaW4tb3V0O1xufVxuXG4uYnV0dG9uOmhvdmVyIHtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAjZjlmYWZiO1xuICAgIGJvcmRlci1jb2xvcjogI2I3YmNjZTtcbiAgICBib3gtc2hhZG93OiAwIDFweCAzcHggMCByZ2JhKDAsIDAsIDAsIDAuMSksIDAgMXB4IDJweCAwIHJnYmEoMCwgMCwgMCwgMC4wNik7XG59XG4iXX0= */";
|
|
5702
|
+
var styles$3 = {"BookEditor":"BookEditor-module_BookEditor__s-0PU","bookEditorContainer":"BookEditor-module_bookEditorContainer__wLMwM","isVerbose":"BookEditor-module_isVerbose__VQ6iL","bookEditorWrapper":"BookEditor-module_bookEditorWrapper__twppD","isBorderRadiusDisabled":"BookEditor-module_isBorderRadiusDisabled__h1I3v","dropOverlay":"BookEditor-module_dropOverlay__xWWoX","bookEditorActionbar":"BookEditor-module_bookEditorActionbar__KW6dc","fullscreen":"BookEditor-module_fullscreen__rktsl","button":"BookEditor-module_button__hS390"};
|
|
5702
5703
|
styleInject(css_248z$4);
|
|
5703
5704
|
|
|
5704
|
-
const version="0.103.0-
|
|
5705
|
+
const version="0.103.0-23";
|
|
5705
5706
|
|
|
5706
|
-
var PipelineCollection = [{title:"Prepare Knowledge from Markdown",pipelineUrl:"https://promptbook.studio/promptbook/prepare-knowledge-from-markdown.book",formfactorName:"GENERIC",parameters:[{name:"knowledgeContent",description:"Markdown document content",isInput:true,isOutput:false},{name:"knowledgePieces",description:"The knowledge JSON object",isInput:false,isOutput:true}],tasks:[{taskType:"PROMPT_TASK",name:"knowledge",title:"Knowledge",content:"You are experienced data researcher, extract the important knowledge from the document.\n\n# Rules\n\n- Make pieces of information concise, clear, and easy to understand\n- One piece of information should be approximately 1 paragraph\n- Divide the paragraphs by markdown horizontal lines ---\n- Omit irrelevant information\n- Group redundant information\n- Write just extracted information, nothing else\n\n# The document\n\nTake information from this document:\n\n> {knowledgeContent}",resultingParameterName:"knowledgePieces",dependentParameterNames:["knowledgeContent"]}],personas:[],preparations:[],knowledgeSources:[],knowledgePieces:[],sources:[{type:"BOOK",path:null,content:"# Prepare Knowledge from Markdown\n\n- PIPELINE URL `https://promptbook.studio/promptbook/prepare-knowledge-from-markdown.book`\n- INPUT PARAMETER `{knowledgeContent}` Markdown document content\n- OUTPUT PARAMETER `{knowledgePieces}` The knowledge JSON object\n\n## Knowledge\n\n<!-- TODO: [🍆] -FORMAT JSON -->\n\n```markdown\nYou are experienced data researcher, extract the important knowledge from the document.\n\n# Rules\n\n- Make pieces of information concise, clear, and easy to understand\n- One piece of information should be approximately 1 paragraph\n- Divide the paragraphs by markdown horizontal lines ---\n- Omit irrelevant information\n- Group redundant information\n- Write just extracted information, nothing else\n\n# The document\n\nTake information from this document:\n\n> {knowledgeContent}\n```\n\n`-> {knowledgePieces}`\n"}],sourceFile:"./books/prepare-knowledge-from-markdown.book"},{title:"Prepare Keywords",pipelineUrl:"https://promptbook.studio/promptbook/prepare-knowledge-keywords.book",formfactorName:"GENERIC",parameters:[{name:"knowledgePieceContent",description:"The content",isInput:true,isOutput:false},{name:"keywords",description:"Keywords separated by comma",isInput:false,isOutput:true}],tasks:[{taskType:"PROMPT_TASK",name:"knowledge",title:"Knowledge",content:"You are experienced data researcher, detect the important keywords in the document.\n\n# Rules\n\n- Write just keywords separated by comma\n\n# The document\n\nTake information from this document:\n\n> {knowledgePieceContent}",resultingParameterName:"keywords",dependentParameterNames:["knowledgePieceContent"]}],personas:[],preparations:[],knowledgeSources:[],knowledgePieces:[],sources:[{type:"BOOK",path:null,content:"# Prepare Keywords\n\n- PIPELINE URL `https://promptbook.studio/promptbook/prepare-knowledge-keywords.book`\n- INPUT PARAMETER `{knowledgePieceContent}` The content\n- OUTPUT PARAMETER `{keywords}` Keywords separated by comma\n\n## Knowledge\n\n<!-- TODO: [🍆] -FORMAT JSON -->\n\n```markdown\nYou are experienced data researcher, detect the important keywords in the document.\n\n# Rules\n\n- Write just keywords separated by comma\n\n# The document\n\nTake information from this document:\n\n> {knowledgePieceContent}\n```\n\n`-> {keywords}`\n"}],sourceFile:"./books/prepare-knowledge-keywords.book"},{title:"Prepare Knowledge-piece Title",pipelineUrl:"https://promptbook.studio/promptbook/prepare-knowledge-title.book",formfactorName:"GENERIC",parameters:[{name:"knowledgePieceContent",description:"The content",isInput:true,isOutput:false},{name:"title",description:"The title of the document",isInput:false,isOutput:true}],tasks:[{taskType:"PROMPT_TASK",name:"knowledge",title:"Knowledge",content:"You are experienced content creator, write best title for the document.\n\n# Rules\n\n- Write just title, nothing else\n- Write maximum 5 words for the title\n\n# The document\n\n> {knowledgePieceContent}",resultingParameterName:"title",expectations:{words:{min:1,max:8}},dependentParameterNames:["knowledgePieceContent"]}],personas:[],preparations:[],knowledgeSources:[],knowledgePieces:[],sources:[{type:"BOOK",path:null,content:"# Prepare Knowledge-piece Title\n\n- PIPELINE URL `https://promptbook.studio/promptbook/prepare-knowledge-title.book`\n- INPUT PARAMETER `{knowledgePieceContent}` The content\n- OUTPUT PARAMETER `{title}` The title of the document\n\n## Knowledge\n\n- EXPECT MIN 1 WORD\n- EXPECT MAX 8 WORDS\n\n```markdown\nYou are experienced content creator, write best title for the document.\n\n# Rules\n\n- Write just title, nothing else\n- Write maximum 5 words for the title\n\n# The document\n\n> {knowledgePieceContent}\n```\n\n`-> {title}`\n"}],sourceFile:"./books/prepare-knowledge-title.book"},{title:"Prepare Persona",pipelineUrl:"https://promptbook.studio/promptbook/prepare-persona.book",formfactorName:"GENERIC",parameters:[{name:"availableModels",description:"List of available model names together with their descriptions as JSON",isInput:true,isOutput:false},{name:"personaDescription",description:"Description of the persona",isInput:true,isOutput:false},{name:"modelsRequirements",description:"Specific requirements for the model",isInput:false,isOutput:true}],tasks:[{taskType:"PROMPT_TASK",name:"make-model-requirements",title:"Make modelRequirements",content:"You are an experienced AI engineer, you need to find the best models for virtual assistants:\n\n## Example\n\n```json\n[\n {\n \"modelName\": \"gpt-4o\",\n \"systemMessage\": \"You are experienced AI engineer and helpful assistant.\",\n \"temperature\": 0.7\n },\n {\n \"modelName\": \"claude-3-5-sonnet\",\n \"systemMessage\": \"You are a friendly and knowledgeable chatbot.\",\n \"temperature\": 0.5\n }\n]\n```\n\n## Instructions\n\n- Your output format is JSON array\n- Sort best-fitting models first\n- Omit any models that are not suitable\n- Write just the JSON, no other text should be present\n- Array contain items with following keys:\n - `modelName`: The name of the model to use\n - `systemMessage`: The system message to provide context to the model\n - `temperature`: The sampling temperature to use\n\n### Key `modelName`\n\nHere are the available models:\n\n```json\n{availableModels}\n```\n\n### Key `systemMessage`\n\nThe system message is used to communicate instructions or provide context to the model at the beginning of a conversation. It is displayed in a different format compared to user messages, helping the model understand its role in the conversation. The system message typically guides the model's behavior, sets the tone, or specifies desired output from the model. By utilizing the system message effectively, users can steer the model towards generating more accurate and relevant responses.\n\nFor example:\n\n> You are an experienced AI engineer and helpful assistant.\n\n> You are a friendly and knowledgeable chatbot.\n\n### Key `temperature`\n\nThe sampling temperature, between 0 and 1. Higher values like 0.8 will make the output more random, while lower values like 0.2 will make it more focused and deterministic. If set to 0, the model will use log probability to automatically increase the temperature until certain thresholds are hit.\n\nYou can pick a value between 0 and 2. For example:\n\n- `0.1`: Low temperature, extremely conservative and deterministic\n- `0.5`: Medium temperature, balanced between conservative and creative\n- `1.0`: High temperature, creative and bit random\n- `1.5`: Very high temperature, extremely creative and often chaotic and unpredictable\n- `2.0`: Maximum temperature, completely random and unpredictable, for some extreme creative use cases\n\n# The assistant\n\nTake this description of the persona:\n\n> {personaDescription}",resultingParameterName:"modelsRequirements",format:"JSON",dependentParameterNames:["availableModels","personaDescription"]}],personas:[],preparations:[],knowledgeSources:[],knowledgePieces:[],sources:[{type:"BOOK",path:null,content:"# Prepare Persona\n\n- PIPELINE URL `https://promptbook.studio/promptbook/prepare-persona.book`\n- INPUT PARAMETER `{availableModels}` List of available model names together with their descriptions as JSON\n- INPUT PARAMETER `{personaDescription}` Description of the persona\n- OUTPUT PARAMETER `{modelsRequirements}` Specific requirements for the model\n\n## Make modelRequirements\n\n- FORMAT JSON\n\n```markdown\nYou are an experienced AI engineer, you need to find the best models for virtual assistants:\n\n## Example\n\n\\`\\`\\`json\n[\n {\n \"modelName\": \"gpt-4o\",\n \"systemMessage\": \"You are experienced AI engineer and helpful assistant.\",\n \"temperature\": 0.7\n },\n {\n \"modelName\": \"claude-3-5-sonnet\",\n \"systemMessage\": \"You are a friendly and knowledgeable chatbot.\",\n \"temperature\": 0.5\n }\n]\n\\`\\`\\`\n\n## Instructions\n\n- Your output format is JSON array\n- Sort best-fitting models first\n- Omit any models that are not suitable\n- Write just the JSON, no other text should be present\n- Array contain items with following keys:\n - `modelName`: The name of the model to use\n - `systemMessage`: The system message to provide context to the model\n - `temperature`: The sampling temperature to use\n\n### Key `modelName`\n\nHere are the available models:\n\n\\`\\`\\`json\n{availableModels}\n\\`\\`\\`\n\n### Key `systemMessage`\n\nThe system message is used to communicate instructions or provide context to the model at the beginning of a conversation. It is displayed in a different format compared to user messages, helping the model understand its role in the conversation. The system message typically guides the model's behavior, sets the tone, or specifies desired output from the model. By utilizing the system message effectively, users can steer the model towards generating more accurate and relevant responses.\n\nFor example:\n\n> You are an experienced AI engineer and helpful assistant.\n\n> You are a friendly and knowledgeable chatbot.\n\n### Key `temperature`\n\nThe sampling temperature, between 0 and 1. Higher values like 0.8 will make the output more random, while lower values like 0.2 will make it more focused and deterministic. If set to 0, the model will use log probability to automatically increase the temperature until certain thresholds are hit.\n\nYou can pick a value between 0 and 2. For example:\n\n- `0.1`: Low temperature, extremely conservative and deterministic\n- `0.5`: Medium temperature, balanced between conservative and creative\n- `1.0`: High temperature, creative and bit random\n- `1.5`: Very high temperature, extremely creative and often chaotic and unpredictable\n- `2.0`: Maximum temperature, completely random and unpredictable, for some extreme creative use cases\n\n# The assistant\n\nTake this description of the persona:\n\n> {personaDescription}\n```\n\n`-> {modelsRequirements}`\n"}],sourceFile:"./books/prepare-persona.book"},{title:"Prepare Title",pipelineUrl:"https://promptbook.studio/promptbook/prepare-title.book",formfactorName:"GENERIC",parameters:[{name:"book",description:"The book to prepare the title for",isInput:true,isOutput:false},{name:"title",description:"Best title for the book",isInput:false,isOutput:true}],tasks:[{taskType:"PROMPT_TASK",name:"make-title",title:"Make title",content:"Make best title for given text which describes the workflow:\n\n## Rules\n\n- Write just title, nothing else\n- Title should be concise and clear - Write maximum ideally 2 words, maximum 5 words\n- Title starts with emoticon\n- Title should not mention the input and output of the workflow but the main purpose of the workflow\n _For example, not \"✍ Convert Knowledge-piece to title\" but \"✍ Title\"_\n\n## The workflow\n\n> {book}",resultingParameterName:"title",expectations:{words:{min:1,max:8},lines:{min:1,max:1}},dependentParameterNames:["book"]}],personas:[],preparations:[],knowledgeSources:[],knowledgePieces:[],sources:[{type:"BOOK",path:null,content:"# Prepare Title\n\n- PIPELINE URL `https://promptbook.studio/promptbook/prepare-title.book`\n- INPUT PARAMETER `{book}` The book to prepare the title for\n- OUTPUT PARAMETER `{title}` Best title for the book\n\n## Make title\n\n- EXPECT MIN 1 Word\n- EXPECT MAX 8 Words\n- EXPECT EXACTLY 1 Line\n\n```markdown\nMake best title for given text which describes the workflow:\n\n## Rules\n\n- Write just title, nothing else\n- Title should be concise and clear - Write maximum ideally 2 words, maximum 5 words\n- Title starts with emoticon\n- Title should not mention the input and output of the workflow but the main purpose of the workflow\n _For example, not \"✍ Convert Knowledge-piece to title\" but \"✍ Title\"_\n\n## The workflow\n\n> {book}\n```\n\n`-> {title}`\n"}],sourceFile:"./books/prepare-title.book"},{title:"📊 Curriculum Audit",pipelineUrl:"https://promptbook.studio/promptbook//examples/lsvp-asistent.book",formfactorName:"GENERIC",parameters:[{name:"result",isInput:false,isOutput:true}],tasks:[{taskType:"PROMPT_TASK",name:"prompt",title:"Prompt",content:"Asistent pro LŠVP\n\nPERSONA Jsi asistent pro RVP Lyceum v rámci Národního pedagogického institutu České Republiky\nMETA IMAGE https://edulk.cz/getFile/id:475818/type:large/02%20zna%C4%8Dka%20npi.jpg\nRULE Pokud jsi nejsi jistý, napiš nevím\nKNOWLEDGE ./241129_Lyceum_final.pdf\nCONTEXT Obecně dokážeš řešit libovolné ŠVP, aktuálně řešíš {Školní vzdělávací program LYCEUM}\nRULE Z {Porovnání RVP a ŠVP - postup} je nejdůležitější fáze 3\nKNOWLEDGE {Školní vzdělávací program LYCEUM} ./ŠVP Lyceum - Finance v digitální době.pdf\nKNOWLEDGE @Slovník\n\n**Interní slovník - RVP/ŠVP**\n\n**RVP**\n\nRámcový vzdělávací program pro obor vzdělání Lyceum je dokument na národní úrovni, který formuluje požadavky na školní vzdělávací programy ve formě především očekávaných výsledků učení, kterých mají žáci absolvováním tohoto programu na dané škole dosáhnout.\n\n**ŠVP**\n\nŠkolní vzdělávací program pro obor vzdělání Lyceum je dokument každé jednotlivé školy, který popisuje v jakých vyučovacích předmětech/ vzdělávacích modulech a v jakých ročnících budou požadované očekávané výsledky učení naplněny. Zároveň formuluje další očekávané výsledky učení, které naplňují disponibilní část vyučovacího času určeného RVP pro tento obor vzdělání.\n\n**Očekávaný výsledek učení (OVU)**\n\nVyjadřuje jednotlivý požadavek na to, co mají žáci umět na konci vzdělávacího programu, tzn. jejich požadované kompetence. Je vyjádřen formulací, která je uvozena činnostním slovesem a dále obsahuje předmět této činnosti. Formulace je konkretizována resp. doplněna zpravidla formou odrážek vymezením dílčích znalostí, dovedností, postojů, jejichž splnění je předpokladem dosažení OVU jako celku.\n\n_Příklad:_\n\n<div class=\"joplin-table-wrapper\"><table><tbody><tr><th><p><strong>Žák/žákyně řídí realizaci jednoduchého projektu</strong></p></th></tr><tr><td><ul><li>naplánuje aktivity projektu</li></ul></td></tr><tr><td><ul><li>navrhne rozpočet projektu vzhledem k navrženým aktivitám</li></ul></td></tr><tr><td><ul><li>stanoví základní ukazatele a sleduje jejich naplňování</li></ul></td></tr><tr><td><ul><li>vede projektový tým</li></ul></td></tr><tr><td><ul><li>uvede, jak by řešil krizové situace v projektu</li></ul></td></tr><tr><td><ul><li>vyhodnotí úspěšnost projektu</li></ul></td></tr></tbody></table></div>\n\n**Vzdělávací oblasti**\n\nOčekávané výsledky učení jsou v **_RVP členěny do 4 vzdělávacích oblastí_**, které tvoří společný všeobecně vzdělávací základ:\n\n- Osobnostní rozvoj, vzdělávání ke zdraví, bezpečí a produktivnímu pracovnímu životu (kariéře)\n- Komunikační a jazykové vzdělávání\n- Aplikované vzdělávání STEM (Science, Technology, Engeneering, Math), tj. přírodní vědy, informatika, technika, matematika\n- Prakticky orientované vzdělávání společenskovědní a humanitní\n\nKaždá vzdělávací oblast se dále člení na okruhy, v jejichž rámci jsou OVU samostatně číslované.\n\n<div class=\"joplin-table-wrapper\"><table><tbody><tr><th rowspan=\"21\"><ul><li>Prakticky orientované vzdělávání společenskovědní a humanitní</li></ul></th><th rowspan=\"21\"><p><strong>Člověk, ekonomie a podnikání</strong></p></th><th rowspan=\"7\"><p><strong>1</strong></p></th><th><p><strong>zpracuje podklady související s podnikáním</strong></p></th></tr><tr><td><p>připraví podnikatelský záměr</p></td></tr><tr><td><p>sestaví zakladatelský rozpočet</p></td></tr><tr><td><p>zkalkuluje cenu zboží nebo služby</p></td></tr><tr><td><p>vysvětlí na příkladu základní povinnosti podnikatele vůči státu a zaměstnancům</p></td></tr><tr><td><p>vede daňovou evidenci</p></td></tr><tr><td><p>vysvětlí na příkladech etiku v podnikání</p></td></tr><tr><td rowspan=\"7\"><p><strong>2</strong></p></td><td><p><strong>řídí realizaci jednoduchého projektu</strong></p></td></tr><tr><td><p>naplánuje aktivity projektu</p></td></tr><tr><td><p>navrhne rozpočet projektu vzhledem k navrženým aktivitám</p></td></tr><tr><td><p>stanoví základní ukazatele a sleduje jejich naplňování</p></td></tr><tr><td><p>vede projektový tým</p></td></tr><tr><td><p>uvede, jak by řešil krizové situace v projektu</p></td></tr><tr><td><p>vyhodnotí úspěšnost projektu</p></td></tr><tr><td rowspan=\"7\"><p><strong>3</strong></p></td><td><p><strong>aplikuje ekonomické teorie v osobním a profesním životě</strong></p></td></tr><tr><td><p>vysvětlí základní ekonomické otázky</p></td></tr><tr><td><p>vysvětí stanovení rovnovážné ceny na dokonalém i nedokonalém trhu</p></td></tr><tr><td><p>charakterizuje výrobní faktory a vysvětlí hranici produkčních možností a náklady obětované příležitosti</p></td></tr><tr><td><p>uvede nejdůležitější makroekonomické pojmy a vliv jejich výše na kvalitu života a podnikání v daném státě</p></td></tr><tr><td><p>vysvětlí podstatu inflace a její důsledky na finanční situaci obyvatel a na příkladu ukáže jak se bránit jejím nepříznivým důsledkům</p></td></tr><tr><td><p>uvede hlavní výhody a nevýhody mezinárodního obchodu a vliv ochranářských opatření na ekonomickou situaci dané země</p></td></tr><tr><td></td><td></td><td><p><strong>4</strong></p></td><td><p>Atd.</p></td></tr></tbody></table></div>\n\n**Vyučovací předmět / vzdělávací modul**\n\nOčekávané výsledky učení jsou v **ŠVP** členěny do vyučovacích předmětů nebo vzdělávacích modulů, které jsou dále zařazeny do jednoho nebo více ročníků 4letého studia. Vyučovací předmět / vzdělávací modul tvoří vyučovací jednotku, kde jsou očekávané výsledky učení dále rozpracovány pro potřeby výuky podle následující šablony\n\n| **A. VSTUPNÍ ČÁST** |\n| --- |\n| **1\\. Název** |\n| **2\\. Kód** (kódy by měly být navázány na obory vzdělání a výsledky učení) |\n| **2a) Kategorie vzdělání** - v případě, že nebude součástí kódu |\n| **3\\. Typ vyučovací jednotky** (modul, předmět, stáž apod.) |\n| **4\\. Délka** (počet hodin - dělitelný čtyřmi (optimální modul 16, 32 hodin = týden výuky) |\n| **5\\. Platnost** (datum, od kterého platí) |\n| **6\\. Vstupní předpoklady** (vymezení požadované úrovně vstupních vědomostí a dovedností, které jsou předpokladem úspěšného studia) |\n| |\n| **B. JÁDRO VYUČOVACÍ JEDNOTKY** |\n| **1\\. Charakteristika** (stručná anotace popisující obecné cíle a pojetí) |\n| **2\\. Očekávané výsledky učení a jejich indikátory (převzaté z RVP nebo dále konkretizované)** |\n| **3\\. Podpora rozvoje klíčových kompetencí a základních gramotností** (které klíčové kompetence jsou v rozvíjeny) |\n| **4\\. Obsah vzdělávání** (rozpis učiva) |\n| **5\\. Vzdělávací strategie** (strategie výuky, resp. učební činnosti žáků, které jsou doporučené pro dosažení výsledků) |\n| |\n| **C. VÝSTUPNÍ ČÁST** |\n| **1\\. Způsob ověřování dosažených výsledků** (ve vazbě na jednotlivé výsledky učení) |\n| **2\\. Kritéria hodnocení** (co znamená splnění výsledků učení, kdy je splněna celá vyučovací jednotka, kritéria pro známky, příp. procentuální, slovní hodnocení) |\n| **3\\. Doporučená studijní literatura, odkazy na ilustrační zdroje** |\n| **4\\. Poznámky** |\n\n**Soulad OVU RVP a ŠVP**\n\nTento soulad je předmětem zjišťování. Soulad nastává, jestliže jsou očekávané výsledky učení z jednotlivých vzdělávacích oblastí RVP **obsaženy** ve vyučovacích předmětech/ vzdělávacích modulech ŠVP jednotlivých škol, tzn. že v ŠVP se objevuje jejich formulace buď v doslovném nebo podobném znění v jednom nebo více vyučovacích předmětech/ vzdělávacích modulech.\n\n_Příklad souladu:_\n\nRVP ŠVP - komunikace a marketing (SŠ obchodní Č.\n\n| **2** | **řídí realizaci jednoduchého projektu** |\n| --- | --- |\n| naplánuje aktivity projektu |\n| navrhne rozpočet projektu vzhledem k navrženým aktivitám |\n| stanoví základní ukazatele a sleduje jejich naplňování |\n| vede projektový tým |\n| uvede, jak by řešil krizové situace v projektu |\n| vyhodnotí úspěšnost projektu |\n\nKNOWLEDGE {Porovnání RVP a ŠVP - postup}\n\n\n# AUDITNÍ PROTOKOL ŠVP-RVP\n\n# (POPIS KONTROLNÍHO ALGORITMU)\n\nMetodika je určena pro **Kvantifikaci Shody** školního vzdělávacího programu (ŠVP) s Rámcovým vzdělávacím programem (RVP).\n\n## FÁZE 1: VALIDACE DOKUMENTACE\n\n**Cíl:** Ověřit platnost, aktuálnost a strukturu zdrojových dokumentů.\n\n- **RVP Verifikace:** Otevřít aktuální verzi RVP (např. RVP ZV/G/SOŠ).\n- **Typová shoda:** Ověřit, že RVP se vztahuje k danému typu školy.\n- **ŠVP Dimenze:** Identifikovat a izolovat relevantní části ŠVP: Profil absolventa, Klíčové kompetence (KK), Vzdělávací oblasti (VO), případně Učební plán (UP).\n- **Verzování:** Potvrdit, že obě verze (RVP a ŠVP) jsou nejnovější a platné (včetně dodatků RVP).\n\n## FÁZE 2: DATABÁZOVÉ MAPOVÁNÍ VÝSTUPŮ (MASTER MATICE)\n\n**Cíl:** Vytvořit systémovou databázi pro křížové porovnání všech povinných komponent RVP se ŠVP.\n\n- **Dekompozice RVP:** Rozložit RVP na základní povinné komponenty: Klíčové kompetence, Vzdělávací oblasti a obory, Očekávané výstupy (OVU), Průřezová témata (PT).\n- **Přiřazovací mapa:** Vytvořit hlavní kontrolní matici (Master Matice) pro záznam vazeb.\n\n| Oblast RVP | Výstup RVP (OVU) | Odpovídající Část ŠVP (Předmět/Ročník) | Konkrétní Tématický Celek v ŠVP | Stav Shody (Protokol) |\n| --- | --- | --- | --- | --- |\n| ... | ... | ... | ... | ... |\n| --- | --- | --- | --- | --- |\n\n## FÁZE 3: ALGORITMICKÁ KONTROLA POKRYTÍ A HLOUBKY\n\n**Cíl:** Posoudit, zda každý povinný výstup RVP je adekvátně reflektován v obsahu ŠVP, a přidělit bodovou hodnotu pro kvantifikaci.\n\n- **Audit OVU:** Projít každý jednotlivý Očekávaný výstup (OVU) z RVP.\n- **Kódování stavu a bodování:** U každého OVU v matici označit stav pokrytí dle následujícího schématu:\n\n| Kód (Protokol) | Popis (Kvalitativní zjištění) | Bodová hodnota (Kvantifikace) |\n| --- | --- | --- |\n| ✅ | Plná shoda (Výstup pokryt v plném rozsahu, odpovídající úrovni RVP) | 1,0 |\n| --- | --- | --- |\n| ⚠️ | Částečná shoda (Formální pokrytí, omezený rozsah, chybná návaznost) | 0,5 |\n| --- | --- | --- |\n| ❌ | Absence (Výstup zcela chybí v obsahu ŠVP) | 0,0 |\n| --- | --- | --- |\n\n- **Defektologie ŠVP:** Identifikovat a zaznamenat deficity ŠVP: Chybějící výstupy (❌), Sémantické překryvy, Přetížení obsahu.\n- **Kvalitativní posun:** Ověřit, zda je formulace výstupů v ŠVP **aktivní, měřitelná a v souladu** s úrovní RVP.\n\n## FÁZE 4: STRUKTURÁLNÍ VERIFIKACE NÁVAZNOSTI (VERTIKÁLA/HORIZONTÁLA)\n\n**Cíl:** Zkontrolovat logickou posloupnost a provázanost učiva v rámci ŠVP.\n\n- **Vertikální Kontrola:** Ověřit posloupnost OVU a učiva uvnitř jednoho předmětu/oblasti (postup od jednodušších ke složitějším konceptům napříč ročníky).\n- **Horizontální Kontrola:** Zkontrolovat logické provázání napříč vzdělávacími oblastmi a předměty (např. fyzika ↔ matematika).\n- **PT Integrace:** Audit reálné integrace Průřezových témat (PT) do konkrétních částí obsahu, metod a projektů.\n\n## FÁZE 5: ANALÝZA ŠKOLNÍ PROFILACE A ROZŠÍŘENÍ RVP\n\n**Cíl:** Validovat, že profilace školy je **v souladu** s RVP a nejedná se o **rozpor**.\n\n- **Nekonfliktnost:** Porovnat definovaný Profil absolventa školy s Klíčovými kompetencemi RVP. Profil ŠVP musí RVP rozvíjet, nikoli mu odporovat.\n- **Modularita:** Zkontrolovat, zda volitelné předměty a rozšiřující moduly logicky navazují na vzdělávací oblasti RVP.\n- **Implementace specializace:** Popisně uvést, jak je školní profilace (např. STEM zaměření, projektová výuka) integrována do OVU a kompetencí definovaných RVP.\n\n## FÁZE 6: GENERÁTOR ZÁVĚREČNÉ ZPRÁVY A KVANTIFIKACE\n\n**Cíl:** Syntetizovat výsledky, kvantifikovat soulad a generovat závazné návrhy na korekce.\n\n### 6.1 Kvantifikace Souladu\n\nVypočítat Index shody (IS) na základě bodového hodnocení (Fáze 3):\n\n### 6.2 Interpretace Indexu Shody (IS)\n\nKlasifikace souladu pro standardizované vyhodnocení:\n\n| Interval IS | Klasifikace souladu | Popis |\n| --- | --- | --- |\n| 95-100 % | Výborný soulad | ŠVP plně odpovídá RVP, pouze stylistické nebo formální rozdíly. |\n| --- | --- | --- |\n| 85-94 % | Dobrá shoda | ŠVP pokrývá všechny klíčové výstupy, menší korekce nutné. |\n| --- | --- | --- |\n| 70-84 % | Částečná shoda | Významné nedostatky v některých oblastech, nutná revize obsahu. |\n| --- | --- | --- |\n| < 70 % | Kritická neshoda | ŠVP neplní rámcové požadavky, ohrožuje legislativní soulad. |\n| --- | --- | --- |\n\n### 6.3 Doplňkové Indexy\n\nVypočítat následující doplňkové indexy pro detailní kvalitativní analýzu:\n\n- **Index kompetenčního souladu (IKS):** Poměr pokrytí klíčových kompetencí RVP v ŠVP.\n- **Index průřezové integrace (IPI):** Míra reálné integrace průřezových témat do výuky.\n- **Index hloubky pokrytí (IHP):** Procento výstupů, které jsou v ŠVP rozvedeny na konkrétní výukové cíle (měřitelné, aktivní formulace).\n- **Index profilové rozšiřitelnosti (IPR):** Kolik rozšiřujících nebo profilových výstupů přesahuje rámec RVP, aniž by narušily jeho strukturu.\n\n### 6.4 Vizuální výstupy\n\nZajistit generování následujících vizualizací pro Závěrečnou zprávu:\n\n- Graf pokrytí po vzdělávacích oblastech (Sloupcový graf IS pro VO).\n- Pavoukový diagram Klíčových kompetencí (RVP vs. ŠVP).\n- Mapa defektů (Vizualizace ❌ a ⚠️ výstupů).\n\n### 6.5 Struktura Závěrečné Zprávy\n\nZpráva musí být strukturována dle standardizovaného formátu:\n\n| Oddíl | Obsah |\n| --- | --- |\n| A. Identifikace | Název školy, IZO, typ školy, datum revize, zpracovatel, verze ŠVP a RVP. |\n| --- | --- |\n| B. Shrnutí výsledků | Celkový Index Shody (IS), hlavní závěry a doporučení. |\n| --- | --- |\n| C. Kvantitativní analýza | Přehled IS v % dle kategorií OVU / VO / kompetencí. |\n| --- | --- |\n| D. Kvalitativní analýza | Slovní zhodnocení kvality souladu (formulace, obtížnost, integrace PT). |\n| --- | --- |\n| E. Rizikové oblasti | Přehled nalezených defektů (chybějící OVU, přetížení, formální shoda). |\n| --- | --- |\n| F. Návrhy opatření (Korekční plán) | Přesné návrhy změn - **Co, Kde, Kdo** má upravit, včetně termínu. |\n| --- | --- |\n| G. Přílohy | Master Matice (Fáze 2-3), revizní tabulka, výstupní grafy a metriky. |\n| --- | --- |\n\n\n\n\n.",resultingParameterName:"result",dependentParameterNames:[]}],personas:[],preparations:[{id:1,promptbookVersion:"0.103.0-20",usage:{price:{value:0},input:{tokensCount:{value:0},charactersCount:{value:0},wordsCount:{value:0},sentencesCount:{value:0},linesCount:{value:0},paragraphsCount:{value:0},pagesCount:{value:0}},output:{tokensCount:{value:0},charactersCount:{value:0},wordsCount:{value:0},sentencesCount:{value:0},linesCount:{value:0},paragraphsCount:{value:0},pagesCount:{value:0}}}}],knowledgeSources:[],knowledgePieces:[],sources:[{type:"BOOK",path:null,content:"Asistent pro LŠVP\n\nPERSONA Jsi asistent pro RVP Lyceum v rámci Národního pedagogického institutu České Republiky\nMETA IMAGE https://edulk.cz/getFile/id:475818/type:large/02%20zna%C4%8Dka%20npi.jpg\nRULE Pokud jsi nejsi jistý, napiš nevím\nKNOWLEDGE ./241129_Lyceum_final.pdf\nCONTEXT Obecně dokážeš řešit libovolné ŠVP, aktuálně řešíš {Školní vzdělávací program LYCEUM}\nRULE Z {Porovnání RVP a ŠVP - postup} je nejdůležitější fáze 3\nKNOWLEDGE {Školní vzdělávací program LYCEUM} ./ŠVP Lyceum - Finance v digitální době.pdf\nKNOWLEDGE @Slovník\n\n**Interní slovník - RVP/ŠVP**\n\n**RVP**\n\nRámcový vzdělávací program pro obor vzdělání Lyceum je dokument na národní úrovni, který formuluje požadavky na školní vzdělávací programy ve formě především očekávaných výsledků učení, kterých mají žáci absolvováním tohoto programu na dané škole dosáhnout.\n\n**ŠVP**\n\nŠkolní vzdělávací program pro obor vzdělání Lyceum je dokument každé jednotlivé školy, který popisuje v jakých vyučovacích předmětech/ vzdělávacích modulech a v jakých ročnících budou požadované očekávané výsledky učení naplněny. Zároveň formuluje další očekávané výsledky učení, které naplňují disponibilní část vyučovacího času určeného RVP pro tento obor vzdělání.\n\n**Očekávaný výsledek učení (OVU)**\n\nVyjadřuje jednotlivý požadavek na to, co mají žáci umět na konci vzdělávacího programu, tzn. jejich požadované kompetence. Je vyjádřen formulací, která je uvozena činnostním slovesem a dále obsahuje předmět této činnosti. Formulace je konkretizována resp. doplněna zpravidla formou odrážek vymezením dílčích znalostí, dovedností, postojů, jejichž splnění je předpokladem dosažení OVU jako celku.\n\n_Příklad:_\n\n<div class=\"joplin-table-wrapper\"><table><tbody><tr><th><p><strong>Žák/žákyně řídí realizaci jednoduchého projektu</strong></p></th></tr><tr><td><ul><li>naplánuje aktivity projektu</li></ul></td></tr><tr><td><ul><li>navrhne rozpočet projektu vzhledem k navrženým aktivitám</li></ul></td></tr><tr><td><ul><li>stanoví základní ukazatele a sleduje jejich naplňování</li></ul></td></tr><tr><td><ul><li>vede projektový tým</li></ul></td></tr><tr><td><ul><li>uvede, jak by řešil krizové situace v projektu</li></ul></td></tr><tr><td><ul><li>vyhodnotí úspěšnost projektu</li></ul></td></tr></tbody></table></div>\n\n**Vzdělávací oblasti**\n\nOčekávané výsledky učení jsou v **_RVP členěny do 4 vzdělávacích oblastí_**, které tvoří společný všeobecně vzdělávací základ:\n\n- Osobnostní rozvoj, vzdělávání ke zdraví, bezpečí a produktivnímu pracovnímu životu (kariéře)\n- Komunikační a jazykové vzdělávání\n- Aplikované vzdělávání STEM (Science, Technology, Engeneering, Math), tj. přírodní vědy, informatika, technika, matematika\n- Prakticky orientované vzdělávání společenskovědní a humanitní\n\nKaždá vzdělávací oblast se dále člení na okruhy, v jejichž rámci jsou OVU samostatně číslované.\n\n<div class=\"joplin-table-wrapper\"><table><tbody><tr><th rowspan=\"21\"><ul><li>Prakticky orientované vzdělávání společenskovědní a humanitní</li></ul></th><th rowspan=\"21\"><p><strong>Člověk, ekonomie a podnikání</strong></p></th><th rowspan=\"7\"><p><strong>1</strong></p></th><th><p><strong>zpracuje podklady související s podnikáním</strong></p></th></tr><tr><td><p>připraví podnikatelský záměr</p></td></tr><tr><td><p>sestaví zakladatelský rozpočet</p></td></tr><tr><td><p>zkalkuluje cenu zboží nebo služby</p></td></tr><tr><td><p>vysvětlí na příkladu základní povinnosti podnikatele vůči státu a zaměstnancům</p></td></tr><tr><td><p>vede daňovou evidenci</p></td></tr><tr><td><p>vysvětlí na příkladech etiku v podnikání</p></td></tr><tr><td rowspan=\"7\"><p><strong>2</strong></p></td><td><p><strong>řídí realizaci jednoduchého projektu</strong></p></td></tr><tr><td><p>naplánuje aktivity projektu</p></td></tr><tr><td><p>navrhne rozpočet projektu vzhledem k navrženým aktivitám</p></td></tr><tr><td><p>stanoví základní ukazatele a sleduje jejich naplňování</p></td></tr><tr><td><p>vede projektový tým</p></td></tr><tr><td><p>uvede, jak by řešil krizové situace v projektu</p></td></tr><tr><td><p>vyhodnotí úspěšnost projektu</p></td></tr><tr><td rowspan=\"7\"><p><strong>3</strong></p></td><td><p><strong>aplikuje ekonomické teorie v osobním a profesním životě</strong></p></td></tr><tr><td><p>vysvětlí základní ekonomické otázky</p></td></tr><tr><td><p>vysvětí stanovení rovnovážné ceny na dokonalém i nedokonalém trhu</p></td></tr><tr><td><p>charakterizuje výrobní faktory a vysvětlí hranici produkčních možností a náklady obětované příležitosti</p></td></tr><tr><td><p>uvede nejdůležitější makroekonomické pojmy a vliv jejich výše na kvalitu života a podnikání v daném státě</p></td></tr><tr><td><p>vysvětlí podstatu inflace a její důsledky na finanční situaci obyvatel a na příkladu ukáže jak se bránit jejím nepříznivým důsledkům</p></td></tr><tr><td><p>uvede hlavní výhody a nevýhody mezinárodního obchodu a vliv ochranářských opatření na ekonomickou situaci dané země</p></td></tr><tr><td></td><td></td><td><p><strong>4</strong></p></td><td><p>Atd.</p></td></tr></tbody></table></div>\n\n**Vyučovací předmět / vzdělávací modul**\n\nOčekávané výsledky učení jsou v **ŠVP** členěny do vyučovacích předmětů nebo vzdělávacích modulů, které jsou dále zařazeny do jednoho nebo více ročníků 4letého studia. Vyučovací předmět / vzdělávací modul tvoří vyučovací jednotku, kde jsou očekávané výsledky učení dále rozpracovány pro potřeby výuky podle následující šablony\n\n| **A. VSTUPNÍ ČÁST** |\n| --- |\n| **1\\. Název** |\n| **2\\. Kód** (kódy by měly být navázány na obory vzdělání a výsledky učení) |\n| **2a) Kategorie vzdělání** - v případě, že nebude součástí kódu |\n| **3\\. Typ vyučovací jednotky** (modul, předmět, stáž apod.) |\n| **4\\. Délka** (počet hodin - dělitelný čtyřmi (optimální modul 16, 32 hodin = týden výuky) |\n| **5\\. Platnost** (datum, od kterého platí) |\n| **6\\. Vstupní předpoklady** (vymezení požadované úrovně vstupních vědomostí a dovedností, které jsou předpokladem úspěšného studia) |\n| |\n| **B. JÁDRO VYUČOVACÍ JEDNOTKY** |\n| **1\\. Charakteristika** (stručná anotace popisující obecné cíle a pojetí) |\n| **2\\. Očekávané výsledky učení a jejich indikátory (převzaté z RVP nebo dále konkretizované)** |\n| **3\\. Podpora rozvoje klíčových kompetencí a základních gramotností** (které klíčové kompetence jsou v rozvíjeny) |\n| **4\\. Obsah vzdělávání** (rozpis učiva) |\n| **5\\. Vzdělávací strategie** (strategie výuky, resp. učební činnosti žáků, které jsou doporučené pro dosažení výsledků) |\n| |\n| **C. VÝSTUPNÍ ČÁST** |\n| **1\\. Způsob ověřování dosažených výsledků** (ve vazbě na jednotlivé výsledky učení) |\n| **2\\. Kritéria hodnocení** (co znamená splnění výsledků učení, kdy je splněna celá vyučovací jednotka, kritéria pro známky, příp. procentuální, slovní hodnocení) |\n| **3\\. Doporučená studijní literatura, odkazy na ilustrační zdroje** |\n| **4\\. Poznámky** |\n\n**Soulad OVU RVP a ŠVP**\n\nTento soulad je předmětem zjišťování. Soulad nastává, jestliže jsou očekávané výsledky učení z jednotlivých vzdělávacích oblastí RVP **obsaženy** ve vyučovacích předmětech/ vzdělávacích modulech ŠVP jednotlivých škol, tzn. že v ŠVP se objevuje jejich formulace buď v doslovném nebo podobném znění v jednom nebo více vyučovacích předmětech/ vzdělávacích modulech.\n\n_Příklad souladu:_\n\nRVP ŠVP - komunikace a marketing (SŠ obchodní Č.\n\n| **2** | **řídí realizaci jednoduchého projektu** |\n| --- | --- |\n| naplánuje aktivity projektu |\n| navrhne rozpočet projektu vzhledem k navrženým aktivitám |\n| stanoví základní ukazatele a sleduje jejich naplňování |\n| vede projektový tým |\n| uvede, jak by řešil krizové situace v projektu |\n| vyhodnotí úspěšnost projektu |\n\nKNOWLEDGE {Porovnání RVP a ŠVP - postup}\n\n\n# AUDITNÍ PROTOKOL ŠVP-RVP\n\n# (POPIS KONTROLNÍHO ALGORITMU)\n\nMetodika je určena pro **Kvantifikaci Shody** školního vzdělávacího programu (ŠVP) s Rámcovým vzdělávacím programem (RVP).\n\n## FÁZE 1: VALIDACE DOKUMENTACE\n\n**Cíl:** Ověřit platnost, aktuálnost a strukturu zdrojových dokumentů.\n\n- **RVP Verifikace:** Otevřít aktuální verzi RVP (např. RVP ZV/G/SOŠ).\n- **Typová shoda:** Ověřit, že RVP se vztahuje k danému typu školy.\n- **ŠVP Dimenze:** Identifikovat a izolovat relevantní části ŠVP: Profil absolventa, Klíčové kompetence (KK), Vzdělávací oblasti (VO), případně Učební plán (UP).\n- **Verzování:** Potvrdit, že obě verze (RVP a ŠVP) jsou nejnovější a platné (včetně dodatků RVP).\n\n## FÁZE 2: DATABÁZOVÉ MAPOVÁNÍ VÝSTUPŮ (MASTER MATICE)\n\n**Cíl:** Vytvořit systémovou databázi pro křížové porovnání všech povinných komponent RVP se ŠVP.\n\n- **Dekompozice RVP:** Rozložit RVP na základní povinné komponenty: Klíčové kompetence, Vzdělávací oblasti a obory, Očekávané výstupy (OVU), Průřezová témata (PT).\n- **Přiřazovací mapa:** Vytvořit hlavní kontrolní matici (Master Matice) pro záznam vazeb.\n\n| Oblast RVP | Výstup RVP (OVU) | Odpovídající Část ŠVP (Předmět/Ročník) | Konkrétní Tématický Celek v ŠVP | Stav Shody (Protokol) |\n| --- | --- | --- | --- | --- |\n| ... | ... | ... | ... | ... |\n| --- | --- | --- | --- | --- |\n\n## FÁZE 3: ALGORITMICKÁ KONTROLA POKRYTÍ A HLOUBKY\n\n**Cíl:** Posoudit, zda každý povinný výstup RVP je adekvátně reflektován v obsahu ŠVP, a přidělit bodovou hodnotu pro kvantifikaci.\n\n- **Audit OVU:** Projít každý jednotlivý Očekávaný výstup (OVU) z RVP.\n- **Kódování stavu a bodování:** U každého OVU v matici označit stav pokrytí dle následujícího schématu:\n\n| Kód (Protokol) | Popis (Kvalitativní zjištění) | Bodová hodnota (Kvantifikace) |\n| --- | --- | --- |\n| ✅ | Plná shoda (Výstup pokryt v plném rozsahu, odpovídající úrovni RVP) | 1,0 |\n| --- | --- | --- |\n| ⚠️ | Částečná shoda (Formální pokrytí, omezený rozsah, chybná návaznost) | 0,5 |\n| --- | --- | --- |\n| ❌ | Absence (Výstup zcela chybí v obsahu ŠVP) | 0,0 |\n| --- | --- | --- |\n\n- **Defektologie ŠVP:** Identifikovat a zaznamenat deficity ŠVP: Chybějící výstupy (❌), Sémantické překryvy, Přetížení obsahu.\n- **Kvalitativní posun:** Ověřit, zda je formulace výstupů v ŠVP **aktivní, měřitelná a v souladu** s úrovní RVP.\n\n## FÁZE 4: STRUKTURÁLNÍ VERIFIKACE NÁVAZNOSTI (VERTIKÁLA/HORIZONTÁLA)\n\n**Cíl:** Zkontrolovat logickou posloupnost a provázanost učiva v rámci ŠVP.\n\n- **Vertikální Kontrola:** Ověřit posloupnost OVU a učiva uvnitř jednoho předmětu/oblasti (postup od jednodušších ke složitějším konceptům napříč ročníky).\n- **Horizontální Kontrola:** Zkontrolovat logické provázání napříč vzdělávacími oblastmi a předměty (např. fyzika ↔ matematika).\n- **PT Integrace:** Audit reálné integrace Průřezových témat (PT) do konkrétních částí obsahu, metod a projektů.\n\n## FÁZE 5: ANALÝZA ŠKOLNÍ PROFILACE A ROZŠÍŘENÍ RVP\n\n**Cíl:** Validovat, že profilace školy je **v souladu** s RVP a nejedná se o **rozpor**.\n\n- **Nekonfliktnost:** Porovnat definovaný Profil absolventa školy s Klíčovými kompetencemi RVP. Profil ŠVP musí RVP rozvíjet, nikoli mu odporovat.\n- **Modularita:** Zkontrolovat, zda volitelné předměty a rozšiřující moduly logicky navazují na vzdělávací oblasti RVP.\n- **Implementace specializace:** Popisně uvést, jak je školní profilace (např. STEM zaměření, projektová výuka) integrována do OVU a kompetencí definovaných RVP.\n\n## FÁZE 6: GENERÁTOR ZÁVĚREČNÉ ZPRÁVY A KVANTIFIKACE\n\n**Cíl:** Syntetizovat výsledky, kvantifikovat soulad a generovat závazné návrhy na korekce.\n\n### 6.1 Kvantifikace Souladu\n\nVypočítat Index shody (IS) na základě bodového hodnocení (Fáze 3):\n\n### 6.2 Interpretace Indexu Shody (IS)\n\nKlasifikace souladu pro standardizované vyhodnocení:\n\n| Interval IS | Klasifikace souladu | Popis |\n| --- | --- | --- |\n| 95-100 % | Výborný soulad | ŠVP plně odpovídá RVP, pouze stylistické nebo formální rozdíly. |\n| --- | --- | --- |\n| 85-94 % | Dobrá shoda | ŠVP pokrývá všechny klíčové výstupy, menší korekce nutné. |\n| --- | --- | --- |\n| 70-84 % | Částečná shoda | Významné nedostatky v některých oblastech, nutná revize obsahu. |\n| --- | --- | --- |\n| < 70 % | Kritická neshoda | ŠVP neplní rámcové požadavky, ohrožuje legislativní soulad. |\n| --- | --- | --- |\n\n### 6.3 Doplňkové Indexy\n\nVypočítat následující doplňkové indexy pro detailní kvalitativní analýzu:\n\n- **Index kompetenčního souladu (IKS):** Poměr pokrytí klíčových kompetencí RVP v ŠVP.\n- **Index průřezové integrace (IPI):** Míra reálné integrace průřezových témat do výuky.\n- **Index hloubky pokrytí (IHP):** Procento výstupů, které jsou v ŠVP rozvedeny na konkrétní výukové cíle (měřitelné, aktivní formulace).\n- **Index profilové rozšiřitelnosti (IPR):** Kolik rozšiřujících nebo profilových výstupů přesahuje rámec RVP, aniž by narušily jeho strukturu.\n\n### 6.4 Vizuální výstupy\n\nZajistit generování následujících vizualizací pro Závěrečnou zprávu:\n\n- Graf pokrytí po vzdělávacích oblastech (Sloupcový graf IS pro VO).\n- Pavoukový diagram Klíčových kompetencí (RVP vs. ŠVP).\n- Mapa defektů (Vizualizace ❌ a ⚠️ výstupů).\n\n### 6.5 Struktura Závěrečné Zprávy\n\nZpráva musí být strukturována dle standardizovaného formátu:\n\n| Oddíl | Obsah |\n| --- | --- |\n| A. Identifikace | Název školy, IZO, typ školy, datum revize, zpracovatel, verze ŠVP a RVP. |\n| --- | --- |\n| B. Shrnutí výsledků | Celkový Index Shody (IS), hlavní závěry a doporučení. |\n| --- | --- |\n| C. Kvantitativní analýza | Přehled IS v % dle kategorií OVU / VO / kompetencí. |\n| --- | --- |\n| D. Kvalitativní analýza | Slovní zhodnocení kvality souladu (formulace, obtížnost, integrace PT). |\n| --- | --- |\n| E. Rizikové oblasti | Přehled nalezených defektů (chybějící OVU, přetížení, formální shoda). |\n| --- | --- |\n| F. Návrhy opatření (Korekční plán) | Přesné návrhy změn - **Co, Kde, Kdo** má upravit, včetně termínu. |\n| --- | --- |\n| G. Přílohy | Master Matice (Fáze 2-3), revizní tabulka, výstupní grafy a metriky. |\n| --- | --- |\n\n\n\n\n.\n"}],sourceFile:"./books/examples/lsvp-asistent.book"}];
|
|
5707
|
+
var PipelineCollection = [{title:"Prepare Knowledge from Markdown",pipelineUrl:"https://promptbook.studio/promptbook/prepare-knowledge-from-markdown.book",formfactorName:"GENERIC",parameters:[{name:"knowledgeContent",description:"Markdown document content",isInput:true,isOutput:false},{name:"knowledgePieces",description:"The knowledge JSON object",isInput:false,isOutput:true}],tasks:[{taskType:"PROMPT_TASK",name:"knowledge",title:"Knowledge",content:"You are experienced data researcher, extract the important knowledge from the document.\n\n# Rules\n\n- Make pieces of information concise, clear, and easy to understand\n- One piece of information should be approximately 1 paragraph\n- Divide the paragraphs by markdown horizontal lines ---\n- Omit irrelevant information\n- Group redundant information\n- Write just extracted information, nothing else\n\n# The document\n\nTake information from this document:\n\n> {knowledgeContent}",resultingParameterName:"knowledgePieces",dependentParameterNames:["knowledgeContent"]}],personas:[],preparations:[],knowledgeSources:[],knowledgePieces:[],sources:[{type:"BOOK",path:null,content:"# Prepare Knowledge from Markdown\n\n- PIPELINE URL `https://promptbook.studio/promptbook/prepare-knowledge-from-markdown.book`\n- INPUT PARAMETER `{knowledgeContent}` Markdown document content\n- OUTPUT PARAMETER `{knowledgePieces}` The knowledge JSON object\n\n## Knowledge\n\n<!-- TODO: [🍆] -FORMAT JSON -->\n\n```markdown\nYou are experienced data researcher, extract the important knowledge from the document.\n\n# Rules\n\n- Make pieces of information concise, clear, and easy to understand\n- One piece of information should be approximately 1 paragraph\n- Divide the paragraphs by markdown horizontal lines ---\n- Omit irrelevant information\n- Group redundant information\n- Write just extracted information, nothing else\n\n# The document\n\nTake information from this document:\n\n> {knowledgeContent}\n```\n\n`-> {knowledgePieces}`\n"}],sourceFile:"./books/prepare-knowledge-from-markdown.book"},{title:"Prepare Keywords",pipelineUrl:"https://promptbook.studio/promptbook/prepare-knowledge-keywords.book",formfactorName:"GENERIC",parameters:[{name:"knowledgePieceContent",description:"The content",isInput:true,isOutput:false},{name:"keywords",description:"Keywords separated by comma",isInput:false,isOutput:true}],tasks:[{taskType:"PROMPT_TASK",name:"knowledge",title:"Knowledge",content:"You are experienced data researcher, detect the important keywords in the document.\n\n# Rules\n\n- Write just keywords separated by comma\n\n# The document\n\nTake information from this document:\n\n> {knowledgePieceContent}",resultingParameterName:"keywords",dependentParameterNames:["knowledgePieceContent"]}],personas:[],preparations:[],knowledgeSources:[],knowledgePieces:[],sources:[{type:"BOOK",path:null,content:"# Prepare Keywords\n\n- PIPELINE URL `https://promptbook.studio/promptbook/prepare-knowledge-keywords.book`\n- INPUT PARAMETER `{knowledgePieceContent}` The content\n- OUTPUT PARAMETER `{keywords}` Keywords separated by comma\n\n## Knowledge\n\n<!-- TODO: [🍆] -FORMAT JSON -->\n\n```markdown\nYou are experienced data researcher, detect the important keywords in the document.\n\n# Rules\n\n- Write just keywords separated by comma\n\n# The document\n\nTake information from this document:\n\n> {knowledgePieceContent}\n```\n\n`-> {keywords}`\n"}],sourceFile:"./books/prepare-knowledge-keywords.book"},{title:"Prepare Knowledge-piece Title",pipelineUrl:"https://promptbook.studio/promptbook/prepare-knowledge-title.book",formfactorName:"GENERIC",parameters:[{name:"knowledgePieceContent",description:"The content",isInput:true,isOutput:false},{name:"title",description:"The title of the document",isInput:false,isOutput:true}],tasks:[{taskType:"PROMPT_TASK",name:"knowledge",title:"Knowledge",content:"You are experienced content creator, write best title for the document.\n\n# Rules\n\n- Write just title, nothing else\n- Write maximum 5 words for the title\n\n# The document\n\n> {knowledgePieceContent}",resultingParameterName:"title",expectations:{words:{min:1,max:8}},dependentParameterNames:["knowledgePieceContent"]}],personas:[],preparations:[],knowledgeSources:[],knowledgePieces:[],sources:[{type:"BOOK",path:null,content:"# Prepare Knowledge-piece Title\n\n- PIPELINE URL `https://promptbook.studio/promptbook/prepare-knowledge-title.book`\n- INPUT PARAMETER `{knowledgePieceContent}` The content\n- OUTPUT PARAMETER `{title}` The title of the document\n\n## Knowledge\n\n- EXPECT MIN 1 WORD\n- EXPECT MAX 8 WORDS\n\n```markdown\nYou are experienced content creator, write best title for the document.\n\n# Rules\n\n- Write just title, nothing else\n- Write maximum 5 words for the title\n\n# The document\n\n> {knowledgePieceContent}\n```\n\n`-> {title}`\n"}],sourceFile:"./books/prepare-knowledge-title.book"},{title:"Prepare Persona",pipelineUrl:"https://promptbook.studio/promptbook/prepare-persona.book",formfactorName:"GENERIC",parameters:[{name:"availableModels",description:"List of available model names together with their descriptions as JSON",isInput:true,isOutput:false},{name:"personaDescription",description:"Description of the persona",isInput:true,isOutput:false},{name:"modelsRequirements",description:"Specific requirements for the model",isInput:false,isOutput:true}],tasks:[{taskType:"PROMPT_TASK",name:"make-model-requirements",title:"Make modelRequirements",content:"You are an experienced AI engineer, you need to find the best models for virtual assistants:\n\n## Example\n\n```json\n[\n {\n \"modelName\": \"gpt-4o\",\n \"systemMessage\": \"You are experienced AI engineer and helpful assistant.\",\n \"temperature\": 0.7\n },\n {\n \"modelName\": \"claude-3-5-sonnet\",\n \"systemMessage\": \"You are a friendly and knowledgeable chatbot.\",\n \"temperature\": 0.5\n }\n]\n```\n\n## Instructions\n\n- Your output format is JSON array\n- Sort best-fitting models first\n- Omit any models that are not suitable\n- Write just the JSON, no other text should be present\n- Array contain items with following keys:\n - `modelName`: The name of the model to use\n - `systemMessage`: The system message to provide context to the model\n - `temperature`: The sampling temperature to use\n\n### Key `modelName`\n\nHere are the available models:\n\n```json\n{availableModels}\n```\n\n### Key `systemMessage`\n\nThe system message is used to communicate instructions or provide context to the model at the beginning of a conversation. It is displayed in a different format compared to user messages, helping the model understand its role in the conversation. The system message typically guides the model's behavior, sets the tone, or specifies desired output from the model. By utilizing the system message effectively, users can steer the model towards generating more accurate and relevant responses.\n\nFor example:\n\n> You are an experienced AI engineer and helpful assistant.\n\n> You are a friendly and knowledgeable chatbot.\n\n### Key `temperature`\n\nThe sampling temperature, between 0 and 1. Higher values like 0.8 will make the output more random, while lower values like 0.2 will make it more focused and deterministic. If set to 0, the model will use log probability to automatically increase the temperature until certain thresholds are hit.\n\nYou can pick a value between 0 and 2. For example:\n\n- `0.1`: Low temperature, extremely conservative and deterministic\n- `0.5`: Medium temperature, balanced between conservative and creative\n- `1.0`: High temperature, creative and bit random\n- `1.5`: Very high temperature, extremely creative and often chaotic and unpredictable\n- `2.0`: Maximum temperature, completely random and unpredictable, for some extreme creative use cases\n\n# The assistant\n\nTake this description of the persona:\n\n> {personaDescription}",resultingParameterName:"modelsRequirements",format:"JSON",dependentParameterNames:["availableModels","personaDescription"]}],personas:[],preparations:[],knowledgeSources:[],knowledgePieces:[],sources:[{type:"BOOK",path:null,content:"# Prepare Persona\n\n- PIPELINE URL `https://promptbook.studio/promptbook/prepare-persona.book`\n- INPUT PARAMETER `{availableModels}` List of available model names together with their descriptions as JSON\n- INPUT PARAMETER `{personaDescription}` Description of the persona\n- OUTPUT PARAMETER `{modelsRequirements}` Specific requirements for the model\n\n## Make modelRequirements\n\n- FORMAT JSON\n\n```markdown\nYou are an experienced AI engineer, you need to find the best models for virtual assistants:\n\n## Example\n\n\\`\\`\\`json\n[\n {\n \"modelName\": \"gpt-4o\",\n \"systemMessage\": \"You are experienced AI engineer and helpful assistant.\",\n \"temperature\": 0.7\n },\n {\n \"modelName\": \"claude-3-5-sonnet\",\n \"systemMessage\": \"You are a friendly and knowledgeable chatbot.\",\n \"temperature\": 0.5\n }\n]\n\\`\\`\\`\n\n## Instructions\n\n- Your output format is JSON array\n- Sort best-fitting models first\n- Omit any models that are not suitable\n- Write just the JSON, no other text should be present\n- Array contain items with following keys:\n - `modelName`: The name of the model to use\n - `systemMessage`: The system message to provide context to the model\n - `temperature`: The sampling temperature to use\n\n### Key `modelName`\n\nHere are the available models:\n\n\\`\\`\\`json\n{availableModels}\n\\`\\`\\`\n\n### Key `systemMessage`\n\nThe system message is used to communicate instructions or provide context to the model at the beginning of a conversation. It is displayed in a different format compared to user messages, helping the model understand its role in the conversation. The system message typically guides the model's behavior, sets the tone, or specifies desired output from the model. By utilizing the system message effectively, users can steer the model towards generating more accurate and relevant responses.\n\nFor example:\n\n> You are an experienced AI engineer and helpful assistant.\n\n> You are a friendly and knowledgeable chatbot.\n\n### Key `temperature`\n\nThe sampling temperature, between 0 and 1. Higher values like 0.8 will make the output more random, while lower values like 0.2 will make it more focused and deterministic. If set to 0, the model will use log probability to automatically increase the temperature until certain thresholds are hit.\n\nYou can pick a value between 0 and 2. For example:\n\n- `0.1`: Low temperature, extremely conservative and deterministic\n- `0.5`: Medium temperature, balanced between conservative and creative\n- `1.0`: High temperature, creative and bit random\n- `1.5`: Very high temperature, extremely creative and often chaotic and unpredictable\n- `2.0`: Maximum temperature, completely random and unpredictable, for some extreme creative use cases\n\n# The assistant\n\nTake this description of the persona:\n\n> {personaDescription}\n```\n\n`-> {modelsRequirements}`\n"}],sourceFile:"./books/prepare-persona.book"},{title:"Prepare Title",pipelineUrl:"https://promptbook.studio/promptbook/prepare-title.book",formfactorName:"GENERIC",parameters:[{name:"book",description:"The book to prepare the title for",isInput:true,isOutput:false},{name:"title",description:"Best title for the book",isInput:false,isOutput:true}],tasks:[{taskType:"PROMPT_TASK",name:"make-title",title:"Make title",content:"Make best title for given text which describes the workflow:\n\n## Rules\n\n- Write just title, nothing else\n- Title should be concise and clear - Write maximum ideally 2 words, maximum 5 words\n- Title starts with emoticon\n- Title should not mention the input and output of the workflow but the main purpose of the workflow\n _For example, not \"✍ Convert Knowledge-piece to title\" but \"✍ Title\"_\n\n## The workflow\n\n> {book}",resultingParameterName:"title",expectations:{words:{min:1,max:8},lines:{min:1,max:1}},dependentParameterNames:["book"]}],personas:[],preparations:[],knowledgeSources:[],knowledgePieces:[],sources:[{type:"BOOK",path:null,content:"# Prepare Title\n\n- PIPELINE URL `https://promptbook.studio/promptbook/prepare-title.book`\n- INPUT PARAMETER `{book}` The book to prepare the title for\n- OUTPUT PARAMETER `{title}` Best title for the book\n\n## Make title\n\n- EXPECT MIN 1 Word\n- EXPECT MAX 8 Words\n- EXPECT EXACTLY 1 Line\n\n```markdown\nMake best title for given text which describes the workflow:\n\n## Rules\n\n- Write just title, nothing else\n- Title should be concise and clear - Write maximum ideally 2 words, maximum 5 words\n- Title starts with emoticon\n- Title should not mention the input and output of the workflow but the main purpose of the workflow\n _For example, not \"✍ Convert Knowledge-piece to title\" but \"✍ Title\"_\n\n## The workflow\n\n> {book}\n```\n\n`-> {title}`\n"}],sourceFile:"./books/prepare-title.book"},{title:"📊 Curriculum Audit",pipelineUrl:"https://promptbook.studio/promptbook//examples/lsvp-asistent.book",formfactorName:"GENERIC",parameters:[{name:"result",isInput:false,isOutput:true}],tasks:[{taskType:"PROMPT_TASK",name:"prompt",title:"Prompt",content:"Asistent pro LŠVP\n\nPERSONA Jsi asistent pro RVP Lyceum v rámci Národního pedagogického institutu České Republiky\nMETA IMAGE https://edulk.cz/getFile/id:475818/type:large/02%20zna%C4%8Dka%20npi.jpg\nRULE Pokud jsi nejsi jistý, napiš nevím\nKNOWLEDGE ./241129_Lyceum_final.pdf\nCONTEXT Obecně dokážeš řešit libovolné ŠVP, aktuálně řešíš {Školní vzdělávací program LYCEUM}\nRULE Z {Porovnání RVP a ŠVP - postup} je nejdůležitější fáze 3\nKNOWLEDGE {Školní vzdělávací program LYCEUM} ./ŠVP Lyceum - Finance v digitální době.pdf\nKNOWLEDGE @Slovník\n\n**Interní slovník - RVP/ŠVP**\n\n**RVP**\n\nRámcový vzdělávací program pro obor vzdělání Lyceum je dokument na národní úrovni, který formuluje požadavky na školní vzdělávací programy ve formě především očekávaných výsledků učení, kterých mají žáci absolvováním tohoto programu na dané škole dosáhnout.\n\n**ŠVP**\n\nŠkolní vzdělávací program pro obor vzdělání Lyceum je dokument každé jednotlivé školy, který popisuje v jakých vyučovacích předmětech/ vzdělávacích modulech a v jakých ročnících budou požadované očekávané výsledky učení naplněny. Zároveň formuluje další očekávané výsledky učení, které naplňují disponibilní část vyučovacího času určeného RVP pro tento obor vzdělání.\n\n**Očekávaný výsledek učení (OVU)**\n\nVyjadřuje jednotlivý požadavek na to, co mají žáci umět na konci vzdělávacího programu, tzn. jejich požadované kompetence. Je vyjádřen formulací, která je uvozena činnostním slovesem a dále obsahuje předmět této činnosti. Formulace je konkretizována resp. doplněna zpravidla formou odrážek vymezením dílčích znalostí, dovedností, postojů, jejichž splnění je předpokladem dosažení OVU jako celku.\n\n_Příklad:_\n\n<div class=\"joplin-table-wrapper\"><table><tbody><tr><th><p><strong>Žák/žákyně řídí realizaci jednoduchého projektu</strong></p></th></tr><tr><td><ul><li>naplánuje aktivity projektu</li></ul></td></tr><tr><td><ul><li>navrhne rozpočet projektu vzhledem k navrženým aktivitám</li></ul></td></tr><tr><td><ul><li>stanoví základní ukazatele a sleduje jejich naplňování</li></ul></td></tr><tr><td><ul><li>vede projektový tým</li></ul></td></tr><tr><td><ul><li>uvede, jak by řešil krizové situace v projektu</li></ul></td></tr><tr><td><ul><li>vyhodnotí úspěšnost projektu</li></ul></td></tr></tbody></table></div>\n\n**Vzdělávací oblasti**\n\nOčekávané výsledky učení jsou v **_RVP členěny do 4 vzdělávacích oblastí_**, které tvoří společný všeobecně vzdělávací základ:\n\n- Osobnostní rozvoj, vzdělávání ke zdraví, bezpečí a produktivnímu pracovnímu životu (kariéře)\n- Komunikační a jazykové vzdělávání\n- Aplikované vzdělávání STEM (Science, Technology, Engeneering, Math), tj. přírodní vědy, informatika, technika, matematika\n- Prakticky orientované vzdělávání společenskovědní a humanitní\n\nKaždá vzdělávací oblast se dále člení na okruhy, v jejichž rámci jsou OVU samostatně číslované.\n\n<div class=\"joplin-table-wrapper\"><table><tbody><tr><th rowspan=\"21\"><ul><li>Prakticky orientované vzdělávání společenskovědní a humanitní</li></ul></th><th rowspan=\"21\"><p><strong>Člověk, ekonomie a podnikání</strong></p></th><th rowspan=\"7\"><p><strong>1</strong></p></th><th><p><strong>zpracuje podklady související s podnikáním</strong></p></th></tr><tr><td><p>připraví podnikatelský záměr</p></td></tr><tr><td><p>sestaví zakladatelský rozpočet</p></td></tr><tr><td><p>zkalkuluje cenu zboží nebo služby</p></td></tr><tr><td><p>vysvětlí na příkladu základní povinnosti podnikatele vůči státu a zaměstnancům</p></td></tr><tr><td><p>vede daňovou evidenci</p></td></tr><tr><td><p>vysvětlí na příkladech etiku v podnikání</p></td></tr><tr><td rowspan=\"7\"><p><strong>2</strong></p></td><td><p><strong>řídí realizaci jednoduchého projektu</strong></p></td></tr><tr><td><p>naplánuje aktivity projektu</p></td></tr><tr><td><p>navrhne rozpočet projektu vzhledem k navrženým aktivitám</p></td></tr><tr><td><p>stanoví základní ukazatele a sleduje jejich naplňování</p></td></tr><tr><td><p>vede projektový tým</p></td></tr><tr><td><p>uvede, jak by řešil krizové situace v projektu</p></td></tr><tr><td><p>vyhodnotí úspěšnost projektu</p></td></tr><tr><td rowspan=\"7\"><p><strong>3</strong></p></td><td><p><strong>aplikuje ekonomické teorie v osobním a profesním životě</strong></p></td></tr><tr><td><p>vysvětlí základní ekonomické otázky</p></td></tr><tr><td><p>vysvětí stanovení rovnovážné ceny na dokonalém i nedokonalém trhu</p></td></tr><tr><td><p>charakterizuje výrobní faktory a vysvětlí hranici produkčních možností a náklady obětované příležitosti</p></td></tr><tr><td><p>uvede nejdůležitější makroekonomické pojmy a vliv jejich výše na kvalitu života a podnikání v daném státě</p></td></tr><tr><td><p>vysvětlí podstatu inflace a její důsledky na finanční situaci obyvatel a na příkladu ukáže jak se bránit jejím nepříznivým důsledkům</p></td></tr><tr><td><p>uvede hlavní výhody a nevýhody mezinárodního obchodu a vliv ochranářských opatření na ekonomickou situaci dané země</p></td></tr><tr><td></td><td></td><td><p><strong>4</strong></p></td><td><p>Atd.</p></td></tr></tbody></table></div>\n\n**Vyučovací předmět / vzdělávací modul**\n\nOčekávané výsledky učení jsou v **ŠVP** členěny do vyučovacích předmětů nebo vzdělávacích modulů, které jsou dále zařazeny do jednoho nebo více ročníků 4letého studia. Vyučovací předmět / vzdělávací modul tvoří vyučovací jednotku, kde jsou očekávané výsledky učení dále rozpracovány pro potřeby výuky podle následující šablony\n\n| **A. VSTUPNÍ ČÁST** |\n| --- |\n| **1\\. Název** |\n| **2\\. Kód** (kódy by měly být navázány na obory vzdělání a výsledky učení) |\n| **2a) Kategorie vzdělání** - v případě, že nebude součástí kódu |\n| **3\\. Typ vyučovací jednotky** (modul, předmět, stáž apod.) |\n| **4\\. Délka** (počet hodin - dělitelný čtyřmi (optimální modul 16, 32 hodin = týden výuky) |\n| **5\\. Platnost** (datum, od kterého platí) |\n| **6\\. Vstupní předpoklady** (vymezení požadované úrovně vstupních vědomostí a dovedností, které jsou předpokladem úspěšného studia) |\n| |\n| **B. JÁDRO VYUČOVACÍ JEDNOTKY** |\n| **1\\. Charakteristika** (stručná anotace popisující obecné cíle a pojetí) |\n| **2\\. Očekávané výsledky učení a jejich indikátory (převzaté z RVP nebo dále konkretizované)** |\n| **3\\. Podpora rozvoje klíčových kompetencí a základních gramotností** (které klíčové kompetence jsou v rozvíjeny) |\n| **4\\. Obsah vzdělávání** (rozpis učiva) |\n| **5\\. Vzdělávací strategie** (strategie výuky, resp. učební činnosti žáků, které jsou doporučené pro dosažení výsledků) |\n| |\n| **C. VÝSTUPNÍ ČÁST** |\n| **1\\. Způsob ověřování dosažených výsledků** (ve vazbě na jednotlivé výsledky učení) |\n| **2\\. Kritéria hodnocení** (co znamená splnění výsledků učení, kdy je splněna celá vyučovací jednotka, kritéria pro známky, příp. procentuální, slovní hodnocení) |\n| **3\\. Doporučená studijní literatura, odkazy na ilustrační zdroje** |\n| **4\\. Poznámky** |\n\n**Soulad OVU RVP a ŠVP**\n\nTento soulad je předmětem zjišťování. Soulad nastává, jestliže jsou očekávané výsledky učení z jednotlivých vzdělávacích oblastí RVP **obsaženy** ve vyučovacích předmětech/ vzdělávacích modulech ŠVP jednotlivých škol, tzn. že v ŠVP se objevuje jejich formulace buď v doslovném nebo podobném znění v jednom nebo více vyučovacích předmětech/ vzdělávacích modulech.\n\n_Příklad souladu:_\n\nRVP ŠVP - komunikace a marketing (SŠ obchodní Č.\n\n| **2** | **řídí realizaci jednoduchého projektu** |\n| --- | --- |\n| naplánuje aktivity projektu |\n| navrhne rozpočet projektu vzhledem k navrženým aktivitám |\n| stanoví základní ukazatele a sleduje jejich naplňování |\n| vede projektový tým |\n| uvede, jak by řešil krizové situace v projektu |\n| vyhodnotí úspěšnost projektu |\n\nKNOWLEDGE {Porovnání RVP a ŠVP - postup}\n\n\n# AUDITNÍ PROTOKOL ŠVP-RVP\n\n# (POPIS KONTROLNÍHO ALGORITMU)\n\nMetodika je určena pro **Kvantifikaci Shody** školního vzdělávacího programu (ŠVP) s Rámcovým vzdělávacím programem (RVP).\n\n## FÁZE 1: VALIDACE DOKUMENTACE\n\n**Cíl:** Ověřit platnost, aktuálnost a strukturu zdrojových dokumentů.\n\n- **RVP Verifikace:** Otevřít aktuální verzi RVP (např. RVP ZV/G/SOŠ).\n- **Typová shoda:** Ověřit, že RVP se vztahuje k danému typu školy.\n- **ŠVP Dimenze:** Identifikovat a izolovat relevantní části ŠVP: Profil absolventa, Klíčové kompetence (KK), Vzdělávací oblasti (VO), případně Učební plán (UP).\n- **Verzování:** Potvrdit, že obě verze (RVP a ŠVP) jsou nejnovější a platné (včetně dodatků RVP).\n\n## FÁZE 2: DATABÁZOVÉ MAPOVÁNÍ VÝSTUPŮ (MASTER MATICE)\n\n**Cíl:** Vytvořit systémovou databázi pro křížové porovnání všech povinných komponent RVP se ŠVP.\n\n- **Dekompozice RVP:** Rozložit RVP na základní povinné komponenty: Klíčové kompetence, Vzdělávací oblasti a obory, Očekávané výstupy (OVU), Průřezová témata (PT).\n- **Přiřazovací mapa:** Vytvořit hlavní kontrolní matici (Master Matice) pro záznam vazeb.\n\n| Oblast RVP | Výstup RVP (OVU) | Odpovídající Část ŠVP (Předmět/Ročník) | Konkrétní Tématický Celek v ŠVP | Stav Shody (Protokol) |\n| --- | --- | --- | --- | --- |\n| ... | ... | ... | ... | ... |\n| --- | --- | --- | --- | --- |\n\n## FÁZE 3: ALGORITMICKÁ KONTROLA POKRYTÍ A HLOUBKY\n\n**Cíl:** Posoudit, zda každý povinný výstup RVP je adekvátně reflektován v obsahu ŠVP, a přidělit bodovou hodnotu pro kvantifikaci.\n\n- **Audit OVU:** Projít každý jednotlivý Očekávaný výstup (OVU) z RVP.\n- **Kódování stavu a bodování:** U každého OVU v matici označit stav pokrytí dle následujícího schématu:\n\n| Kód (Protokol) | Popis (Kvalitativní zjištění) | Bodová hodnota (Kvantifikace) |\n| --- | --- | --- |\n| ✅ | Plná shoda (Výstup pokryt v plném rozsahu, odpovídající úrovni RVP) | 1,0 |\n| --- | --- | --- |\n| ⚠️ | Částečná shoda (Formální pokrytí, omezený rozsah, chybná návaznost) | 0,5 |\n| --- | --- | --- |\n| ❌ | Absence (Výstup zcela chybí v obsahu ŠVP) | 0,0 |\n| --- | --- | --- |\n\n- **Defektologie ŠVP:** Identifikovat a zaznamenat deficity ŠVP: Chybějící výstupy (❌), Sémantické překryvy, Přetížení obsahu.\n- **Kvalitativní posun:** Ověřit, zda je formulace výstupů v ŠVP **aktivní, měřitelná a v souladu** s úrovní RVP.\n\n## FÁZE 4: STRUKTURÁLNÍ VERIFIKACE NÁVAZNOSTI (VERTIKÁLA/HORIZONTÁLA)\n\n**Cíl:** Zkontrolovat logickou posloupnost a provázanost učiva v rámci ŠVP.\n\n- **Vertikální Kontrola:** Ověřit posloupnost OVU a učiva uvnitř jednoho předmětu/oblasti (postup od jednodušších ke složitějším konceptům napříč ročníky).\n- **Horizontální Kontrola:** Zkontrolovat logické provázání napříč vzdělávacími oblastmi a předměty (např. fyzika ↔ matematika).\n- **PT Integrace:** Audit reálné integrace Průřezových témat (PT) do konkrétních částí obsahu, metod a projektů.\n\n## FÁZE 5: ANALÝZA ŠKOLNÍ PROFILACE A ROZŠÍŘENÍ RVP\n\n**Cíl:** Validovat, že profilace školy je **v souladu** s RVP a nejedná se o **rozpor**.\n\n- **Nekonfliktnost:** Porovnat definovaný Profil absolventa školy s Klíčovými kompetencemi RVP. Profil ŠVP musí RVP rozvíjet, nikoli mu odporovat.\n- **Modularita:** Zkontrolovat, zda volitelné předměty a rozšiřující moduly logicky navazují na vzdělávací oblasti RVP.\n- **Implementace specializace:** Popisně uvést, jak je školní profilace (např. STEM zaměření, projektová výuka) integrována do OVU a kompetencí definovaných RVP.\n\n## FÁZE 6: GENERÁTOR ZÁVĚREČNÉ ZPRÁVY A KVANTIFIKACE\n\n**Cíl:** Syntetizovat výsledky, kvantifikovat soulad a generovat závazné návrhy na korekce.\n\n### 6.1 Kvantifikace Souladu\n\nVypočítat Index shody (IS) na základě bodového hodnocení (Fáze 3):\n\n### 6.2 Interpretace Indexu Shody (IS)\n\nKlasifikace souladu pro standardizované vyhodnocení:\n\n| Interval IS | Klasifikace souladu | Popis |\n| --- | --- | --- |\n| 95-100 % | Výborný soulad | ŠVP plně odpovídá RVP, pouze stylistické nebo formální rozdíly. |\n| --- | --- | --- |\n| 85-94 % | Dobrá shoda | ŠVP pokrývá všechny klíčové výstupy, menší korekce nutné. |\n| --- | --- | --- |\n| 70-84 % | Částečná shoda | Významné nedostatky v některých oblastech, nutná revize obsahu. |\n| --- | --- | --- |\n| < 70 % | Kritická neshoda | ŠVP neplní rámcové požadavky, ohrožuje legislativní soulad. |\n| --- | --- | --- |\n\n### 6.3 Doplňkové Indexy\n\nVypočítat následující doplňkové indexy pro detailní kvalitativní analýzu:\n\n- **Index kompetenčního souladu (IKS):** Poměr pokrytí klíčových kompetencí RVP v ŠVP.\n- **Index průřezové integrace (IPI):** Míra reálné integrace průřezových témat do výuky.\n- **Index hloubky pokrytí (IHP):** Procento výstupů, které jsou v ŠVP rozvedeny na konkrétní výukové cíle (měřitelné, aktivní formulace).\n- **Index profilové rozšiřitelnosti (IPR):** Kolik rozšiřujících nebo profilových výstupů přesahuje rámec RVP, aniž by narušily jeho strukturu.\n\n### 6.4 Vizuální výstupy\n\nZajistit generování následujících vizualizací pro Závěrečnou zprávu:\n\n- Graf pokrytí po vzdělávacích oblastech (Sloupcový graf IS pro VO).\n- Pavoukový diagram Klíčových kompetencí (RVP vs. ŠVP).\n- Mapa defektů (Vizualizace ❌ a ⚠️ výstupů).\n\n### 6.5 Struktura Závěrečné Zprávy\n\nZpráva musí být strukturována dle standardizovaného formátu:\n\n| Oddíl | Obsah |\n| --- | --- |\n| A. Identifikace | Název školy, IZO, typ školy, datum revize, zpracovatel, verze ŠVP a RVP. |\n| --- | --- |\n| B. Shrnutí výsledků | Celkový Index Shody (IS), hlavní závěry a doporučení. |\n| --- | --- |\n| C. Kvantitativní analýza | Přehled IS v % dle kategorií OVU / VO / kompetencí. |\n| --- | --- |\n| D. Kvalitativní analýza | Slovní zhodnocení kvality souladu (formulace, obtížnost, integrace PT). |\n| --- | --- |\n| E. Rizikové oblasti | Přehled nalezených defektů (chybějící OVU, přetížení, formální shoda). |\n| --- | --- |\n| F. Návrhy opatření (Korekční plán) | Přesné návrhy změn - **Co, Kde, Kdo** má upravit, včetně termínu. |\n| --- | --- |\n| G. Přílohy | Master Matice (Fáze 2-3), revizní tabulka, výstupní grafy a metriky. |\n| --- | --- |\n\n\n\n\n.",resultingParameterName:"result",dependentParameterNames:[]}],personas:[],preparations:[{id:1,promptbookVersion:"0.103.0-22",usage:{price:{value:0},input:{tokensCount:{value:0},charactersCount:{value:0},wordsCount:{value:0},sentencesCount:{value:0},linesCount:{value:0},paragraphsCount:{value:0},pagesCount:{value:0}},output:{tokensCount:{value:0},charactersCount:{value:0},wordsCount:{value:0},sentencesCount:{value:0},linesCount:{value:0},paragraphsCount:{value:0},pagesCount:{value:0}}}}],knowledgeSources:[],knowledgePieces:[],sources:[{type:"BOOK",path:null,content:"Asistent pro LŠVP\n\nPERSONA Jsi asistent pro RVP Lyceum v rámci Národního pedagogického institutu České Republiky\nMETA IMAGE https://edulk.cz/getFile/id:475818/type:large/02%20zna%C4%8Dka%20npi.jpg\nRULE Pokud jsi nejsi jistý, napiš nevím\nKNOWLEDGE ./241129_Lyceum_final.pdf\nCONTEXT Obecně dokážeš řešit libovolné ŠVP, aktuálně řešíš {Školní vzdělávací program LYCEUM}\nRULE Z {Porovnání RVP a ŠVP - postup} je nejdůležitější fáze 3\nKNOWLEDGE {Školní vzdělávací program LYCEUM} ./ŠVP Lyceum - Finance v digitální době.pdf\nKNOWLEDGE @Slovník\n\n**Interní slovník - RVP/ŠVP**\n\n**RVP**\n\nRámcový vzdělávací program pro obor vzdělání Lyceum je dokument na národní úrovni, který formuluje požadavky na školní vzdělávací programy ve formě především očekávaných výsledků učení, kterých mají žáci absolvováním tohoto programu na dané škole dosáhnout.\n\n**ŠVP**\n\nŠkolní vzdělávací program pro obor vzdělání Lyceum je dokument každé jednotlivé školy, který popisuje v jakých vyučovacích předmětech/ vzdělávacích modulech a v jakých ročnících budou požadované očekávané výsledky učení naplněny. Zároveň formuluje další očekávané výsledky učení, které naplňují disponibilní část vyučovacího času určeného RVP pro tento obor vzdělání.\n\n**Očekávaný výsledek učení (OVU)**\n\nVyjadřuje jednotlivý požadavek na to, co mají žáci umět na konci vzdělávacího programu, tzn. jejich požadované kompetence. Je vyjádřen formulací, která je uvozena činnostním slovesem a dále obsahuje předmět této činnosti. Formulace je konkretizována resp. doplněna zpravidla formou odrážek vymezením dílčích znalostí, dovedností, postojů, jejichž splnění je předpokladem dosažení OVU jako celku.\n\n_Příklad:_\n\n<div class=\"joplin-table-wrapper\"><table><tbody><tr><th><p><strong>Žák/žákyně řídí realizaci jednoduchého projektu</strong></p></th></tr><tr><td><ul><li>naplánuje aktivity projektu</li></ul></td></tr><tr><td><ul><li>navrhne rozpočet projektu vzhledem k navrženým aktivitám</li></ul></td></tr><tr><td><ul><li>stanoví základní ukazatele a sleduje jejich naplňování</li></ul></td></tr><tr><td><ul><li>vede projektový tým</li></ul></td></tr><tr><td><ul><li>uvede, jak by řešil krizové situace v projektu</li></ul></td></tr><tr><td><ul><li>vyhodnotí úspěšnost projektu</li></ul></td></tr></tbody></table></div>\n\n**Vzdělávací oblasti**\n\nOčekávané výsledky učení jsou v **_RVP členěny do 4 vzdělávacích oblastí_**, které tvoří společný všeobecně vzdělávací základ:\n\n- Osobnostní rozvoj, vzdělávání ke zdraví, bezpečí a produktivnímu pracovnímu životu (kariéře)\n- Komunikační a jazykové vzdělávání\n- Aplikované vzdělávání STEM (Science, Technology, Engeneering, Math), tj. přírodní vědy, informatika, technika, matematika\n- Prakticky orientované vzdělávání společenskovědní a humanitní\n\nKaždá vzdělávací oblast se dále člení na okruhy, v jejichž rámci jsou OVU samostatně číslované.\n\n<div class=\"joplin-table-wrapper\"><table><tbody><tr><th rowspan=\"21\"><ul><li>Prakticky orientované vzdělávání společenskovědní a humanitní</li></ul></th><th rowspan=\"21\"><p><strong>Člověk, ekonomie a podnikání</strong></p></th><th rowspan=\"7\"><p><strong>1</strong></p></th><th><p><strong>zpracuje podklady související s podnikáním</strong></p></th></tr><tr><td><p>připraví podnikatelský záměr</p></td></tr><tr><td><p>sestaví zakladatelský rozpočet</p></td></tr><tr><td><p>zkalkuluje cenu zboží nebo služby</p></td></tr><tr><td><p>vysvětlí na příkladu základní povinnosti podnikatele vůči státu a zaměstnancům</p></td></tr><tr><td><p>vede daňovou evidenci</p></td></tr><tr><td><p>vysvětlí na příkladech etiku v podnikání</p></td></tr><tr><td rowspan=\"7\"><p><strong>2</strong></p></td><td><p><strong>řídí realizaci jednoduchého projektu</strong></p></td></tr><tr><td><p>naplánuje aktivity projektu</p></td></tr><tr><td><p>navrhne rozpočet projektu vzhledem k navrženým aktivitám</p></td></tr><tr><td><p>stanoví základní ukazatele a sleduje jejich naplňování</p></td></tr><tr><td><p>vede projektový tým</p></td></tr><tr><td><p>uvede, jak by řešil krizové situace v projektu</p></td></tr><tr><td><p>vyhodnotí úspěšnost projektu</p></td></tr><tr><td rowspan=\"7\"><p><strong>3</strong></p></td><td><p><strong>aplikuje ekonomické teorie v osobním a profesním životě</strong></p></td></tr><tr><td><p>vysvětlí základní ekonomické otázky</p></td></tr><tr><td><p>vysvětí stanovení rovnovážné ceny na dokonalém i nedokonalém trhu</p></td></tr><tr><td><p>charakterizuje výrobní faktory a vysvětlí hranici produkčních možností a náklady obětované příležitosti</p></td></tr><tr><td><p>uvede nejdůležitější makroekonomické pojmy a vliv jejich výše na kvalitu života a podnikání v daném státě</p></td></tr><tr><td><p>vysvětlí podstatu inflace a její důsledky na finanční situaci obyvatel a na příkladu ukáže jak se bránit jejím nepříznivým důsledkům</p></td></tr><tr><td><p>uvede hlavní výhody a nevýhody mezinárodního obchodu a vliv ochranářských opatření na ekonomickou situaci dané země</p></td></tr><tr><td></td><td></td><td><p><strong>4</strong></p></td><td><p>Atd.</p></td></tr></tbody></table></div>\n\n**Vyučovací předmět / vzdělávací modul**\n\nOčekávané výsledky učení jsou v **ŠVP** členěny do vyučovacích předmětů nebo vzdělávacích modulů, které jsou dále zařazeny do jednoho nebo více ročníků 4letého studia. Vyučovací předmět / vzdělávací modul tvoří vyučovací jednotku, kde jsou očekávané výsledky učení dále rozpracovány pro potřeby výuky podle následující šablony\n\n| **A. VSTUPNÍ ČÁST** |\n| --- |\n| **1\\. Název** |\n| **2\\. Kód** (kódy by měly být navázány na obory vzdělání a výsledky učení) |\n| **2a) Kategorie vzdělání** - v případě, že nebude součástí kódu |\n| **3\\. Typ vyučovací jednotky** (modul, předmět, stáž apod.) |\n| **4\\. Délka** (počet hodin - dělitelný čtyřmi (optimální modul 16, 32 hodin = týden výuky) |\n| **5\\. Platnost** (datum, od kterého platí) |\n| **6\\. Vstupní předpoklady** (vymezení požadované úrovně vstupních vědomostí a dovedností, které jsou předpokladem úspěšného studia) |\n| |\n| **B. JÁDRO VYUČOVACÍ JEDNOTKY** |\n| **1\\. Charakteristika** (stručná anotace popisující obecné cíle a pojetí) |\n| **2\\. Očekávané výsledky učení a jejich indikátory (převzaté z RVP nebo dále konkretizované)** |\n| **3\\. Podpora rozvoje klíčových kompetencí a základních gramotností** (které klíčové kompetence jsou v rozvíjeny) |\n| **4\\. Obsah vzdělávání** (rozpis učiva) |\n| **5\\. Vzdělávací strategie** (strategie výuky, resp. učební činnosti žáků, které jsou doporučené pro dosažení výsledků) |\n| |\n| **C. VÝSTUPNÍ ČÁST** |\n| **1\\. Způsob ověřování dosažených výsledků** (ve vazbě na jednotlivé výsledky učení) |\n| **2\\. Kritéria hodnocení** (co znamená splnění výsledků učení, kdy je splněna celá vyučovací jednotka, kritéria pro známky, příp. procentuální, slovní hodnocení) |\n| **3\\. Doporučená studijní literatura, odkazy na ilustrační zdroje** |\n| **4\\. Poznámky** |\n\n**Soulad OVU RVP a ŠVP**\n\nTento soulad je předmětem zjišťování. Soulad nastává, jestliže jsou očekávané výsledky učení z jednotlivých vzdělávacích oblastí RVP **obsaženy** ve vyučovacích předmětech/ vzdělávacích modulech ŠVP jednotlivých škol, tzn. že v ŠVP se objevuje jejich formulace buď v doslovném nebo podobném znění v jednom nebo více vyučovacích předmětech/ vzdělávacích modulech.\n\n_Příklad souladu:_\n\nRVP ŠVP - komunikace a marketing (SŠ obchodní Č.\n\n| **2** | **řídí realizaci jednoduchého projektu** |\n| --- | --- |\n| naplánuje aktivity projektu |\n| navrhne rozpočet projektu vzhledem k navrženým aktivitám |\n| stanoví základní ukazatele a sleduje jejich naplňování |\n| vede projektový tým |\n| uvede, jak by řešil krizové situace v projektu |\n| vyhodnotí úspěšnost projektu |\n\nKNOWLEDGE {Porovnání RVP a ŠVP - postup}\n\n\n# AUDITNÍ PROTOKOL ŠVP-RVP\n\n# (POPIS KONTROLNÍHO ALGORITMU)\n\nMetodika je určena pro **Kvantifikaci Shody** školního vzdělávacího programu (ŠVP) s Rámcovým vzdělávacím programem (RVP).\n\n## FÁZE 1: VALIDACE DOKUMENTACE\n\n**Cíl:** Ověřit platnost, aktuálnost a strukturu zdrojových dokumentů.\n\n- **RVP Verifikace:** Otevřít aktuální verzi RVP (např. RVP ZV/G/SOŠ).\n- **Typová shoda:** Ověřit, že RVP se vztahuje k danému typu školy.\n- **ŠVP Dimenze:** Identifikovat a izolovat relevantní části ŠVP: Profil absolventa, Klíčové kompetence (KK), Vzdělávací oblasti (VO), případně Učební plán (UP).\n- **Verzování:** Potvrdit, že obě verze (RVP a ŠVP) jsou nejnovější a platné (včetně dodatků RVP).\n\n## FÁZE 2: DATABÁZOVÉ MAPOVÁNÍ VÝSTUPŮ (MASTER MATICE)\n\n**Cíl:** Vytvořit systémovou databázi pro křížové porovnání všech povinných komponent RVP se ŠVP.\n\n- **Dekompozice RVP:** Rozložit RVP na základní povinné komponenty: Klíčové kompetence, Vzdělávací oblasti a obory, Očekávané výstupy (OVU), Průřezová témata (PT).\n- **Přiřazovací mapa:** Vytvořit hlavní kontrolní matici (Master Matice) pro záznam vazeb.\n\n| Oblast RVP | Výstup RVP (OVU) | Odpovídající Část ŠVP (Předmět/Ročník) | Konkrétní Tématický Celek v ŠVP | Stav Shody (Protokol) |\n| --- | --- | --- | --- | --- |\n| ... | ... | ... | ... | ... |\n| --- | --- | --- | --- | --- |\n\n## FÁZE 3: ALGORITMICKÁ KONTROLA POKRYTÍ A HLOUBKY\n\n**Cíl:** Posoudit, zda každý povinný výstup RVP je adekvátně reflektován v obsahu ŠVP, a přidělit bodovou hodnotu pro kvantifikaci.\n\n- **Audit OVU:** Projít každý jednotlivý Očekávaný výstup (OVU) z RVP.\n- **Kódování stavu a bodování:** U každého OVU v matici označit stav pokrytí dle následujícího schématu:\n\n| Kód (Protokol) | Popis (Kvalitativní zjištění) | Bodová hodnota (Kvantifikace) |\n| --- | --- | --- |\n| ✅ | Plná shoda (Výstup pokryt v plném rozsahu, odpovídající úrovni RVP) | 1,0 |\n| --- | --- | --- |\n| ⚠️ | Částečná shoda (Formální pokrytí, omezený rozsah, chybná návaznost) | 0,5 |\n| --- | --- | --- |\n| ❌ | Absence (Výstup zcela chybí v obsahu ŠVP) | 0,0 |\n| --- | --- | --- |\n\n- **Defektologie ŠVP:** Identifikovat a zaznamenat deficity ŠVP: Chybějící výstupy (❌), Sémantické překryvy, Přetížení obsahu.\n- **Kvalitativní posun:** Ověřit, zda je formulace výstupů v ŠVP **aktivní, měřitelná a v souladu** s úrovní RVP.\n\n## FÁZE 4: STRUKTURÁLNÍ VERIFIKACE NÁVAZNOSTI (VERTIKÁLA/HORIZONTÁLA)\n\n**Cíl:** Zkontrolovat logickou posloupnost a provázanost učiva v rámci ŠVP.\n\n- **Vertikální Kontrola:** Ověřit posloupnost OVU a učiva uvnitř jednoho předmětu/oblasti (postup od jednodušších ke složitějším konceptům napříč ročníky).\n- **Horizontální Kontrola:** Zkontrolovat logické provázání napříč vzdělávacími oblastmi a předměty (např. fyzika ↔ matematika).\n- **PT Integrace:** Audit reálné integrace Průřezových témat (PT) do konkrétních částí obsahu, metod a projektů.\n\n## FÁZE 5: ANALÝZA ŠKOLNÍ PROFILACE A ROZŠÍŘENÍ RVP\n\n**Cíl:** Validovat, že profilace školy je **v souladu** s RVP a nejedná se o **rozpor**.\n\n- **Nekonfliktnost:** Porovnat definovaný Profil absolventa školy s Klíčovými kompetencemi RVP. Profil ŠVP musí RVP rozvíjet, nikoli mu odporovat.\n- **Modularita:** Zkontrolovat, zda volitelné předměty a rozšiřující moduly logicky navazují na vzdělávací oblasti RVP.\n- **Implementace specializace:** Popisně uvést, jak je školní profilace (např. STEM zaměření, projektová výuka) integrována do OVU a kompetencí definovaných RVP.\n\n## FÁZE 6: GENERÁTOR ZÁVĚREČNÉ ZPRÁVY A KVANTIFIKACE\n\n**Cíl:** Syntetizovat výsledky, kvantifikovat soulad a generovat závazné návrhy na korekce.\n\n### 6.1 Kvantifikace Souladu\n\nVypočítat Index shody (IS) na základě bodového hodnocení (Fáze 3):\n\n### 6.2 Interpretace Indexu Shody (IS)\n\nKlasifikace souladu pro standardizované vyhodnocení:\n\n| Interval IS | Klasifikace souladu | Popis |\n| --- | --- | --- |\n| 95-100 % | Výborný soulad | ŠVP plně odpovídá RVP, pouze stylistické nebo formální rozdíly. |\n| --- | --- | --- |\n| 85-94 % | Dobrá shoda | ŠVP pokrývá všechny klíčové výstupy, menší korekce nutné. |\n| --- | --- | --- |\n| 70-84 % | Částečná shoda | Významné nedostatky v některých oblastech, nutná revize obsahu. |\n| --- | --- | --- |\n| < 70 % | Kritická neshoda | ŠVP neplní rámcové požadavky, ohrožuje legislativní soulad. |\n| --- | --- | --- |\n\n### 6.3 Doplňkové Indexy\n\nVypočítat následující doplňkové indexy pro detailní kvalitativní analýzu:\n\n- **Index kompetenčního souladu (IKS):** Poměr pokrytí klíčových kompetencí RVP v ŠVP.\n- **Index průřezové integrace (IPI):** Míra reálné integrace průřezových témat do výuky.\n- **Index hloubky pokrytí (IHP):** Procento výstupů, které jsou v ŠVP rozvedeny na konkrétní výukové cíle (měřitelné, aktivní formulace).\n- **Index profilové rozšiřitelnosti (IPR):** Kolik rozšiřujících nebo profilových výstupů přesahuje rámec RVP, aniž by narušily jeho strukturu.\n\n### 6.4 Vizuální výstupy\n\nZajistit generování následujících vizualizací pro Závěrečnou zprávu:\n\n- Graf pokrytí po vzdělávacích oblastech (Sloupcový graf IS pro VO).\n- Pavoukový diagram Klíčových kompetencí (RVP vs. ŠVP).\n- Mapa defektů (Vizualizace ❌ a ⚠️ výstupů).\n\n### 6.5 Struktura Závěrečné Zprávy\n\nZpráva musí být strukturována dle standardizovaného formátu:\n\n| Oddíl | Obsah |\n| --- | --- |\n| A. Identifikace | Název školy, IZO, typ školy, datum revize, zpracovatel, verze ŠVP a RVP. |\n| --- | --- |\n| B. Shrnutí výsledků | Celkový Index Shody (IS), hlavní závěry a doporučení. |\n| --- | --- |\n| C. Kvantitativní analýza | Přehled IS v % dle kategorií OVU / VO / kompetencí. |\n| --- | --- |\n| D. Kvalitativní analýza | Slovní zhodnocení kvality souladu (formulace, obtížnost, integrace PT). |\n| --- | --- |\n| E. Rizikové oblasti | Přehled nalezených defektů (chybějící OVU, přetížení, formální shoda). |\n| --- | --- |\n| F. Návrhy opatření (Korekční plán) | Přesné návrhy změn - **Co, Kde, Kdo** má upravit, včetně termínu. |\n| --- | --- |\n| G. Přílohy | Master Matice (Fáze 2-3), revizní tabulka, výstupní grafy a metriky. |\n| --- | --- |\n\n\n\n\n.\n"}],sourceFile:"./books/examples/lsvp-asistent.book"}];
|
|
5707
5708
|
|
|
5708
5709
|
/**
|
|
5709
5710
|
* Function `validatePipelineString` will validate the if the string is a valid pipeline string
|
|
@@ -9760,7 +9761,8 @@
|
|
|
9760
9761
|
function createEmptyAgentModelRequirements() {
|
|
9761
9762
|
return {
|
|
9762
9763
|
systemMessage: '',
|
|
9763
|
-
modelName: 'gpt-5',
|
|
9764
|
+
// modelName: 'gpt-5',
|
|
9765
|
+
modelName: 'gemini-2.5-flash-lite',
|
|
9764
9766
|
temperature: 0.7,
|
|
9765
9767
|
topP: 0.9,
|
|
9766
9768
|
topK: 50,
|
|
@@ -11303,12 +11305,30 @@
|
|
|
11303
11305
|
return (jsxRuntime.jsx("svg", { xmlns: "http://www.w3.org/2000/svg", width: size || 24, height: size || 24, viewBox: "0 0 24 24", fill: "currentColor", ...rest, children: jsxRuntime.jsx("path", { d: "M5 20h14v-2H5v2zm14-9h-4V3H9v8H5l7 7 7-7z" }) }));
|
|
11304
11306
|
}
|
|
11305
11307
|
|
|
11308
|
+
/**
|
|
11309
|
+
* Renders an icon that represents the exit fullscreen action
|
|
11310
|
+
*
|
|
11311
|
+
* @private
|
|
11312
|
+
*/
|
|
11313
|
+
function ExitFullscreenIcon() {
|
|
11314
|
+
return (jsxRuntime.jsxs("svg", { width: "1em", height: "1em", viewBox: "0 0 24 24", fill: "none", xmlns: "http://www.w3.org/2000/svg", "aria-hidden": "true", children: [jsxRuntime.jsx("path", { d: "M14 10L20 4M14 10H18M14 10V6", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round" }), jsxRuntime.jsx("path", { d: "M10 14L4 20M10 14H6M10 14V18", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round" }), jsxRuntime.jsx("path", { d: "M4 10L10 4M4 10H8M4 10V6", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round" }), jsxRuntime.jsx("path", { d: "M20 14L14 20M20 14H16M20 14V18", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round" })] }));
|
|
11315
|
+
}
|
|
11316
|
+
|
|
11317
|
+
/**
|
|
11318
|
+
* Renders an icon that represents the fullscreen action
|
|
11319
|
+
*
|
|
11320
|
+
* @private
|
|
11321
|
+
*/
|
|
11322
|
+
function FullscreenIcon() {
|
|
11323
|
+
return (jsxRuntime.jsxs("svg", { width: "1em", height: "1em", viewBox: "0 0 24 24", fill: "none", xmlns: "http://www.w3.org/2000/svg", "aria-hidden": "true", children: [jsxRuntime.jsx("path", { d: "M4 20L10 14M4 20V16M4 20H8", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round" }), jsxRuntime.jsx("path", { d: "M20 4L14 10M20 4V8M20 4H16", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round" }), jsxRuntime.jsx("path", { d: "M4 4L10 10M4 4V8M4 4H8", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round" }), jsxRuntime.jsx("path", { d: "M20 20L14 14M20 20V16M20 20H16", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round" })] }));
|
|
11324
|
+
}
|
|
11325
|
+
|
|
11306
11326
|
/**
|
|
11307
11327
|
*
|
|
11308
11328
|
* @private Internal component used by `BookEditor`
|
|
11309
11329
|
*/
|
|
11310
11330
|
function BookEditorActionbar(props) {
|
|
11311
|
-
const { value, isDownloadButtonShown, isAboutButtonShown } = props;
|
|
11331
|
+
const { value, isDownloadButtonShown, isAboutButtonShown, isFullscreenButtonShown, onFullscreenClick, isFullscreen, } = props;
|
|
11312
11332
|
const [isAboutModalOpen, setIsAboutModalOpen] = react.useState(false);
|
|
11313
11333
|
const handleDownload = () => {
|
|
11314
11334
|
const book = validateBook(value || DEFAULT_BOOK);
|
|
@@ -11329,6 +11349,16 @@
|
|
|
11329
11349
|
onClick: () => setIsAboutModalOpen(true),
|
|
11330
11350
|
});
|
|
11331
11351
|
}
|
|
11352
|
+
if (isFullscreenButtonShown && onFullscreenClick) {
|
|
11353
|
+
actions.push({
|
|
11354
|
+
icon: jsxRuntime.jsx(FullscreenIcon, {}),
|
|
11355
|
+
name: 'Fullscreen',
|
|
11356
|
+
onClick: onFullscreenClick,
|
|
11357
|
+
});
|
|
11358
|
+
}
|
|
11359
|
+
if (isFullscreen) {
|
|
11360
|
+
return (jsxRuntime.jsx("div", { className: styles$3.bookEditorActionbar, children: jsxRuntime.jsx("button", { className: styles$3.button, onClick: onFullscreenClick, children: jsxRuntime.jsx(ExitFullscreenIcon, {}) }) }));
|
|
11361
|
+
}
|
|
11332
11362
|
return (jsxRuntime.jsxs("div", { className: styles$3.bookEditorActionbar, children: [actions.length >= 2 ? (jsxRuntime.jsx(Dropdown, { actions: actions })) : (actions.map(({ icon, name, onClick }) => (jsxRuntime.jsxs("button", { className: styles$3.button, onClick: onClick, children: [icon, jsxRuntime.jsx("span", { children: name })] }, name)))), isAboutModalOpen && (jsxRuntime.jsxs(Modal, { onClose: () => {
|
|
11333
11363
|
setIsAboutModalOpen(false);
|
|
11334
11364
|
}, children: [jsxRuntime.jsx("h2", { children: "Promptbook Editor" }), jsxRuntime.jsx("p", { children: "This is an editor for the Promptbook." }), jsxRuntime.jsxs("p", { children: ["Version: ", jsxRuntime.jsx("b", { children: version })] })] }))] }));
|
|
@@ -11346,7 +11376,7 @@
|
|
|
11346
11376
|
* @private Internal component used by `BookEditor`
|
|
11347
11377
|
*/
|
|
11348
11378
|
function BookEditorMonaco(props) {
|
|
11349
|
-
const { value, onChange, isReadonly, translations, onFileUpload, isDownloadButtonShown, isAboutButtonShown = true, zoom = 1,
|
|
11379
|
+
const { value, onChange, isReadonly, translations, onFileUpload, isDownloadButtonShown, isAboutButtonShown = true, isFullscreenButtonShown = true, onFullscreenClick, isFullscreen, zoom = 1,
|
|
11350
11380
|
// [🚱]> sync,
|
|
11351
11381
|
} = props;
|
|
11352
11382
|
const zoomLevel = zoom;
|
|
@@ -11546,7 +11576,12 @@
|
|
|
11546
11576
|
event.preventDefault();
|
|
11547
11577
|
setIsDragOver(false);
|
|
11548
11578
|
}, []);
|
|
11549
|
-
return (jsxRuntime.jsxs("div", { className: classNames(styles$3.bookEditorContainer, instanceClass), onDrop: handleDrop, onDragOver: handleDragOver, onDragEnter: handleDragEnter, onDragLeave: handleDragLeave, children: [(isDownloadButtonShown || isAboutButtonShown
|
|
11579
|
+
return (jsxRuntime.jsxs("div", { className: classNames(styles$3.bookEditorContainer, instanceClass), onDrop: handleDrop, onDragOver: handleDragOver, onDragEnter: handleDragEnter, onDragLeave: handleDragLeave, children: [(isDownloadButtonShown || isAboutButtonShown || isFullscreenButtonShown) && (jsxRuntime.jsx(BookEditorActionbar, { value,
|
|
11580
|
+
isDownloadButtonShown,
|
|
11581
|
+
isAboutButtonShown,
|
|
11582
|
+
isFullscreenButtonShown,
|
|
11583
|
+
onFullscreenClick,
|
|
11584
|
+
isFullscreen })), isDragOver && jsxRuntime.jsx("div", { className: styles$3.dropOverlay, children: "Drop files to upload" }), jsxRuntime.jsx(Editor__default["default"], { language: BOOK_LANGUAGE_ID, value: value,
|
|
11550
11585
|
// [🚱]> onMount={(editor) => setEditor(editor)}
|
|
11551
11586
|
onChange: (newValue) => onChange === null || onChange === void 0 ? void 0 : onChange(newValue), options: {
|
|
11552
11587
|
readOnly: isReadonly,
|
|
@@ -11557,7 +11592,7 @@
|
|
|
11557
11592
|
minimap: { enabled: false },
|
|
11558
11593
|
lineNumbers: 'off',
|
|
11559
11594
|
fontSize: scaledFontSize,
|
|
11560
|
-
// TODO: [🚚] Allow to pass font family as prop
|
|
11595
|
+
// TODO: [🚚] Allow to pass font family as prop + Make the font asset hosted on Promptbook CDN side
|
|
11561
11596
|
fontFamily: `"Playfair Display", serif`,
|
|
11562
11597
|
// [🚚]> fontFamily: `"Bitcount Grid Single", system-ui`,
|
|
11563
11598
|
lineHeight: scaledLineHeight,
|
|
@@ -11591,8 +11626,12 @@
|
|
|
11591
11626
|
* @public exported from `@promptbook/components`
|
|
11592
11627
|
*/
|
|
11593
11628
|
function BookEditor(props) {
|
|
11594
|
-
const { agentSource, className, style, zoom = 1, value, onChange, onFileUpload, isVerbose = DEFAULT_IS_VERBOSE, isBorderRadiusDisabled = false, isReadonly = false, translations, isDownloadButtonShown = true, isAboutButtonShown = true, sync, } = props;
|
|
11595
|
-
|
|
11629
|
+
const { agentSource, className, style, zoom = 1, value, onChange, onFileUpload, isVerbose = DEFAULT_IS_VERBOSE, isBorderRadiusDisabled = false, isReadonly = false, translations, isDownloadButtonShown = true, isAboutButtonShown = true, isFullscreenButtonShown = true, sync, } = props;
|
|
11630
|
+
const [isFullscreen, setIsFullscreen] = react.useState(false);
|
|
11631
|
+
const handleFullscreenToggle = () => {
|
|
11632
|
+
setIsFullscreen(!isFullscreen);
|
|
11633
|
+
};
|
|
11634
|
+
return (jsxRuntime.jsx("div", { "data-book-component": "BookEditor", className: classNames(styles$3.BookEditor, isVerbose && styles$3.isVerbose, styles$3.bookEditorWrapper, isBorderRadiusDisabled && styles$3.isBorderRadiusDisabled, isFullscreen && styles$3.fullscreen, className), style: {
|
|
11596
11635
|
...(style || {}),
|
|
11597
11636
|
...(props.height === null
|
|
11598
11637
|
? {}
|
|
@@ -11601,7 +11640,7 @@
|
|
|
11601
11640
|
? `${props.height}px`
|
|
11602
11641
|
: props.height || `${DEFAULT_BOOK_EDITOR_HEIGHT}px`,
|
|
11603
11642
|
}),
|
|
11604
|
-
}, children: jsxRuntime.jsx(BookEditorMonaco, { value: agentSource || value, onChange: onChange, onFileUpload: onFileUpload, isVerbose: isVerbose, isBorderRadiusDisabled: isBorderRadiusDisabled, isReadonly: isReadonly, translations: translations, isDownloadButtonShown: isDownloadButtonShown, isAboutButtonShown: isAboutButtonShown, sync: sync, zoom: zoom }) }));
|
|
11643
|
+
}, children: jsxRuntime.jsx(BookEditorMonaco, { value: agentSource || value, onChange: onChange, onFileUpload: onFileUpload, isVerbose: isVerbose, isBorderRadiusDisabled: isBorderRadiusDisabled, isReadonly: isReadonly, translations: translations, isDownloadButtonShown: isDownloadButtonShown, isAboutButtonShown: isAboutButtonShown, isFullscreenButtonShown: isFullscreenButtonShown, onFullscreenClick: handleFullscreenToggle, isFullscreen: isFullscreen, sync: sync, zoom: zoom }) }));
|
|
11605
11644
|
}
|
|
11606
11645
|
|
|
11607
11646
|
var css_248z$2 = ".AvatarProfile-module_AvatarProfile__CUARY{align-items:flex-start;background:#f0f4f8;border:1px solid #e0e7ef;border-radius:8px;display:flex;padding:16px}.AvatarProfile-module_Avatar__-iSnq{border-radius:50%;flex-shrink:0;height:64px;margin-right:16px;object-fit:cover;width:64px}.AvatarProfile-module_AgentInfo__W0TR6{display:flex;flex-direction:column}.AvatarProfile-module_AgentName__9v6Qk{color:#2a3b4d;font-size:1.25em;font-weight:600;margin:0}.AvatarProfile-module_AgentTitle__nnAQM{color:#5a6b7d;font-size:1em;font-weight:500;margin:4px 0 0}.AvatarProfile-module_AgentDescription__ExidJ{color:#5a6b7d;font-size:.9em;margin:8px 0 0}.AvatarProfile-module_viewSourceButton__oi0dE{background-color:#fff;border:1px solid #e0e7ef;border-radius:6px;color:#2a3b4d;cursor:pointer;font-size:.9em;font-weight:500;margin-top:12px;padding:8px 12px;transition:background-color .2s}.AvatarProfile-module_viewSourceButton__oi0dE:hover{background-color:#f0f4f8}\n/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkF2YXRhclByb2ZpbGUubW9kdWxlLmNzcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSwyQ0FFSSxzQkFBdUIsQ0FHdkIsa0JBQW1CLENBQ25CLHdCQUF5QixDQUZ6QixpQkFBa0IsQ0FIbEIsWUFBYSxDQUViLFlBSUosQ0FFQSxvQ0FHSSxpQkFBa0IsQ0FHbEIsYUFBYyxDQUpkLFdBQVksQ0FHWixpQkFBa0IsQ0FEbEIsZ0JBQWlCLENBSGpCLFVBTUosQ0FFQSx1Q0FDSSxZQUFhLENBQ2IscUJBQ0osQ0FFQSx1Q0FJSSxhQUFjLENBRmQsZ0JBQWlCLENBQ2pCLGVBQWdCLENBRmhCLFFBSUosQ0FFQSx3Q0FJSSxhQUFjLENBRmQsYUFBYyxDQUNkLGVBQWdCLENBRmhCLGNBSUosQ0FFQSw4Q0FHSSxhQUFjLENBRGQsY0FBZ0IsQ0FEaEIsY0FHSixDQUVBLDhDQUtJLHFCQUFzQixDQUZ0Qix3QkFBeUIsQ0FDekIsaUJBQWtCLENBRWxCLGFBQWMsQ0FHZCxjQUFlLENBRmYsY0FBZ0IsQ0FDaEIsZUFBZ0IsQ0FQaEIsZUFBZ0IsQ0FDaEIsZ0JBQWlCLENBUWpCLCtCQUNKLENBRUEsb0RBQ0ksd0JBQ0oiLCJmaWxlIjoiQXZhdGFyUHJvZmlsZS5tb2R1bGUuY3NzIiwic291cmNlc0NvbnRlbnQiOlsiLkF2YXRhclByb2ZpbGUge1xuICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgYWxpZ24taXRlbXM6IGZsZXgtc3RhcnQ7XG4gICAgcGFkZGluZzogMTZweDtcbiAgICBib3JkZXItcmFkaXVzOiA4cHg7XG4gICAgYmFja2dyb3VuZDogI2YwZjRmODtcbiAgICBib3JkZXI6IDFweCBzb2xpZCAjZTBlN2VmO1xufVxuXG4uQXZhdGFyIHtcbiAgICB3aWR0aDogNjRweDtcbiAgICBoZWlnaHQ6IDY0cHg7XG4gICAgYm9yZGVyLXJhZGl1czogNTAlO1xuICAgIG9iamVjdC1maXQ6IGNvdmVyO1xuICAgIG1hcmdpbi1yaWdodDogMTZweDtcbiAgICBmbGV4LXNocmluazogMDtcbn1cblxuLkFnZW50SW5mbyB7XG4gICAgZGlzcGxheTogZmxleDtcbiAgICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xufVxuXG4uQWdlbnROYW1lIHtcbiAgICBtYXJnaW46IDA7XG4gICAgZm9udC1zaXplOiAxLjI1ZW07XG4gICAgZm9udC13ZWlnaHQ6IDYwMDtcbiAgICBjb2xvcjogIzJhM2I0ZDtcbn1cblxuLkFnZW50VGl0bGUge1xuICAgIG1hcmdpbjogNHB4IDAgMCAwO1xuICAgIGZvbnQtc2l6ZTogMWVtO1xuICAgIGZvbnQtd2VpZ2h0OiA1MDA7XG4gICAgY29sb3I6ICM1YTZiN2Q7XG59XG5cbi5BZ2VudERlc2NyaXB0aW9uIHtcbiAgICBtYXJnaW46IDhweCAwIDAgMDtcbiAgICBmb250LXNpemU6IDAuOWVtO1xuICAgIGNvbG9yOiAjNWE2YjdkO1xufVxuXG4udmlld1NvdXJjZUJ1dHRvbiB7XG4gICAgbWFyZ2luLXRvcDogMTJweDtcbiAgICBwYWRkaW5nOiA4cHggMTJweDtcbiAgICBib3JkZXI6IDFweCBzb2xpZCAjZTBlN2VmO1xuICAgIGJvcmRlci1yYWRpdXM6IDZweDtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAjZmZmO1xuICAgIGNvbG9yOiAjMmEzYjRkO1xuICAgIGZvbnQtc2l6ZTogMC45ZW07XG4gICAgZm9udC13ZWlnaHQ6IDUwMDtcbiAgICBjdXJzb3I6IHBvaW50ZXI7XG4gICAgdHJhbnNpdGlvbjogYmFja2dyb3VuZC1jb2xvciAwLjJzO1xufVxuXG4udmlld1NvdXJjZUJ1dHRvbjpob3ZlciB7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogI2YwZjRmODtcbn1cbiJdfQ== */";
|
|
@@ -11636,19 +11675,6 @@
|
|
|
11636
11675
|
return jsxRuntime.jsx(AvatarProfile, { ...rest, agent: agent, agentSource: agentSource });
|
|
11637
11676
|
}
|
|
11638
11677
|
|
|
11639
|
-
/**
|
|
11640
|
-
* Default font class name for the BookEditor component
|
|
11641
|
-
* In Next.js environments, you can override this by importing the font directly
|
|
11642
|
-
*
|
|
11643
|
-
* @public exported from `@promptbook/components`
|
|
11644
|
-
* @deprecated !!! Remove
|
|
11645
|
-
*/
|
|
11646
|
-
const DEFAULT_BOOK_FONT_CLASS = styles$3.bookEditorSerif;
|
|
11647
|
-
// <- Note: This results in something like `BookEditor-module_bookEditorSerif__QRS7g` in the production
|
|
11648
|
-
/**
|
|
11649
|
-
* Note: [💞] Ignore a discrepancy between file name and entity name
|
|
11650
|
-
*/
|
|
11651
|
-
|
|
11652
11678
|
/**
|
|
11653
11679
|
* Shows simple arrow icon pointing up or down
|
|
11654
11680
|
*
|
|
@@ -11666,12 +11692,12 @@
|
|
|
11666
11692
|
}
|
|
11667
11693
|
|
|
11668
11694
|
/**
|
|
11669
|
-
*
|
|
11695
|
+
* Renders an icon that represents the close action
|
|
11670
11696
|
*
|
|
11671
|
-
* @
|
|
11697
|
+
* @private
|
|
11672
11698
|
*/
|
|
11673
|
-
function CloseIcon(
|
|
11674
|
-
return (jsxRuntime.jsx("svg", { width:
|
|
11699
|
+
function CloseIcon() {
|
|
11700
|
+
return (jsxRuntime.jsx("svg", { width: "1em", height: "1em", viewBox: "0 0 24 24", fill: "none", xmlns: "http://www.w3.org/2000/svg", "aria-hidden": "true", children: jsxRuntime.jsx("path", { d: "M18 6L6 18M6 6l12 12", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round" }) }));
|
|
11675
11701
|
}
|
|
11676
11702
|
|
|
11677
11703
|
/**
|
|
@@ -12365,9 +12391,10 @@
|
|
|
12365
12391
|
*
|
|
12366
12392
|
* @public exported from `@promptbook/components`
|
|
12367
12393
|
*/
|
|
12368
|
-
function MarkdownContent(
|
|
12394
|
+
function MarkdownContent(props) {
|
|
12395
|
+
const { content, className } = props;
|
|
12369
12396
|
const htmlContent = react.useMemo(() => renderMarkdown(content), [content]);
|
|
12370
|
-
return (jsxRuntime.jsx("div", { dangerouslySetInnerHTML: {
|
|
12397
|
+
return (jsxRuntime.jsx("div", { className: className, dangerouslySetInnerHTML: {
|
|
12371
12398
|
__html: htmlContent,
|
|
12372
12399
|
} }));
|
|
12373
12400
|
}
|
|
@@ -12916,7 +12943,7 @@
|
|
|
12916
12943
|
onDragOver: handleDragOver,
|
|
12917
12944
|
onDragLeave: handleDragLeave,
|
|
12918
12945
|
}
|
|
12919
|
-
: {}), children: [uploadedFiles.length > 0 && (jsxRuntime.jsx("div", { className: chatStyles.filePreviewContainer, children: uploadedFiles.map((uploadedFile) => (jsxRuntime.jsxs("div", { className: chatStyles.filePreview, children: [jsxRuntime.jsx("div", { className: chatStyles.fileIcon, children: "\uD83D\uDCCE" }), jsxRuntime.jsxs("div", { className: chatStyles.fileInfo, children: [jsxRuntime.jsx("div", { className: chatStyles.fileName, children: uploadedFile.file.name }), jsxRuntime.jsxs("div", { className: chatStyles.fileSize, children: [(uploadedFile.file.size / 1024).toFixed(1), " KB"] })] }), jsxRuntime.jsx("button", { className: chatStyles.removeFileButton, onClick: () => removeUploadedFile(uploadedFile.id), title: "Remove file", children: jsxRuntime.jsx(CloseIcon
|
|
12946
|
+
: {}), children: [uploadedFiles.length > 0 && (jsxRuntime.jsx("div", { className: chatStyles.filePreviewContainer, children: uploadedFiles.map((uploadedFile) => (jsxRuntime.jsxs("div", { className: chatStyles.filePreview, children: [jsxRuntime.jsx("div", { className: chatStyles.fileIcon, children: "\uD83D\uDCCE" }), jsxRuntime.jsxs("div", { className: chatStyles.fileInfo, children: [jsxRuntime.jsx("div", { className: chatStyles.fileName, children: uploadedFile.file.name }), jsxRuntime.jsxs("div", { className: chatStyles.fileSize, children: [(uploadedFile.file.size / 1024).toFixed(1), " KB"] })] }), jsxRuntime.jsx("button", { className: chatStyles.removeFileButton, onClick: () => removeUploadedFile(uploadedFile.id), title: "Remove file", children: jsxRuntime.jsx(CloseIcon /* !!! size={12}*/, {}) })] }, uploadedFile.id))) })), (() => {
|
|
12920
12947
|
var _a, _b, _c;
|
|
12921
12948
|
// Note: Find the isMe participant or fallback to default
|
|
12922
12949
|
const myColor = ((_a = participants.find((p) => p.isMe)) === null || _a === void 0 ? void 0 : _a.color) || USER_CHAT_COLOR;
|
|
@@ -13624,6 +13651,214 @@
|
|
|
13624
13651
|
onMessage: isSimulationComplete && chatProps.onMessage ? chatProps.onMessage : undefined }));
|
|
13625
13652
|
}
|
|
13626
13653
|
|
|
13654
|
+
/**
|
|
13655
|
+
*
|
|
13656
|
+
*
|
|
13657
|
+
* @private utility of QR code components
|
|
13658
|
+
*/
|
|
13659
|
+
function useQrCode(options) {
|
|
13660
|
+
const { value, logoSrc, ...restOptions } = options;
|
|
13661
|
+
const canvasRef = react.useRef(null);
|
|
13662
|
+
react.useEffect(() => {
|
|
13663
|
+
if (!canvasRef.current) {
|
|
13664
|
+
console.log('!!! !canvasRef.current');
|
|
13665
|
+
return;
|
|
13666
|
+
}
|
|
13667
|
+
const canvas = canvasRef.current;
|
|
13668
|
+
QRCode__default["default"].toCanvas(canvas, value.toString(), restOptions, (error) => {
|
|
13669
|
+
console.log('!!! QR code generated');
|
|
13670
|
+
if (error) {
|
|
13671
|
+
console.error(error);
|
|
13672
|
+
return;
|
|
13673
|
+
}
|
|
13674
|
+
if (!logoSrc) {
|
|
13675
|
+
console.log('!!! !logoSrc');
|
|
13676
|
+
return;
|
|
13677
|
+
}
|
|
13678
|
+
const ctx = canvas.getContext('2d');
|
|
13679
|
+
if (!ctx) {
|
|
13680
|
+
console.error('!!! Failed to get canvas 2D context');
|
|
13681
|
+
return;
|
|
13682
|
+
}
|
|
13683
|
+
const logo = new Image();
|
|
13684
|
+
logo.src = logoSrc;
|
|
13685
|
+
logo.onload = () => {
|
|
13686
|
+
console.log('!!! Logo loaded for QR code');
|
|
13687
|
+
const logoSize = canvas.width / 4;
|
|
13688
|
+
const logoX = (canvas.width - logoSize) / 2;
|
|
13689
|
+
const logoY = (canvas.height - logoSize) / 2;
|
|
13690
|
+
ctx.drawImage(logo, logoX, logoY, logoSize, logoSize);
|
|
13691
|
+
};
|
|
13692
|
+
});
|
|
13693
|
+
}, [value, logoSrc]);
|
|
13694
|
+
return { canvasRef };
|
|
13695
|
+
}
|
|
13696
|
+
|
|
13697
|
+
/**
|
|
13698
|
+
* @public exported from `@promptbook/components`
|
|
13699
|
+
*/
|
|
13700
|
+
function BrandedQrCode(props) {
|
|
13701
|
+
const { value, logoSrc, size = 250, className } = props;
|
|
13702
|
+
const { canvasRef } = useQrCode({ value, logoSrc });
|
|
13703
|
+
return (jsxRuntime.jsx("div", { className: className, children: jsxRuntime.jsx("canvas", { ref: canvasRef, width: size, height: size }) }));
|
|
13704
|
+
}
|
|
13705
|
+
|
|
13706
|
+
/**
|
|
13707
|
+
* @public exported from `@promptbook/components`
|
|
13708
|
+
*/
|
|
13709
|
+
function GenericQrCode({ value, size = 250, className }) {
|
|
13710
|
+
const { canvasRef } = useQrCode({ value });
|
|
13711
|
+
return (jsxRuntime.jsx("div", { className: className, children: jsxRuntime.jsx("canvas", { ref: canvasRef, width: size, height: size }) }));
|
|
13712
|
+
}
|
|
13713
|
+
|
|
13714
|
+
const PROMPTBOOK_LOGO_DATAURL = `data:image/png;base64,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`;
|
|
13715
|
+
// <- TODO: Remove this and use actual img imported logo
|
|
13716
|
+
/**
|
|
13717
|
+
* @public exported from `@promptbook/components`
|
|
13718
|
+
*/
|
|
13719
|
+
function PromptbookQrCode(props) {
|
|
13720
|
+
const { value, className, size = 250 } = props;
|
|
13721
|
+
const generateQRCode = async (canvasElement, options) => {
|
|
13722
|
+
const QRCodeGenerator = (await import('qrcode')).default;
|
|
13723
|
+
// Draw QR code first
|
|
13724
|
+
await new Promise((resolve, reject) => {
|
|
13725
|
+
QRCodeGenerator.toCanvas(canvasElement, value.toString(), options, (error) => {
|
|
13726
|
+
if (error) {
|
|
13727
|
+
console.error(error);
|
|
13728
|
+
reject(error);
|
|
13729
|
+
}
|
|
13730
|
+
else {
|
|
13731
|
+
resolve();
|
|
13732
|
+
}
|
|
13733
|
+
});
|
|
13734
|
+
});
|
|
13735
|
+
// Add logo after QR code is drawn
|
|
13736
|
+
const ctx = canvasElement.getContext('2d');
|
|
13737
|
+
if (!ctx)
|
|
13738
|
+
return;
|
|
13739
|
+
const logo = new Image();
|
|
13740
|
+
logo.src = PROMPTBOOK_LOGO_DATAURL;
|
|
13741
|
+
await new Promise((resolve) => {
|
|
13742
|
+
logo.onload = () => {
|
|
13743
|
+
// Calculate the size of a single QR code module based on canvas dimensions and margin.
|
|
13744
|
+
// We still need to make an assumption about the number of modules per side,
|
|
13745
|
+
// as the library doesn't expose it directly after drawing.
|
|
13746
|
+
// For error correction level 'H', and a reasonable amount of data for a logo,
|
|
13747
|
+
// the version is likely between 7 and 15 (45x45 to 77x77 modules).
|
|
13748
|
+
// Let's use an estimated average or a value that has worked well.
|
|
13749
|
+
// A common size for a logo-inclusive QR code is version 7 (45 modules) or higher.
|
|
13750
|
+
// Let's estimate based on version 10 (57 modules) as a starting point,
|
|
13751
|
+
// as it was used in previous attempts and might be close.
|
|
13752
|
+
const estimatedModulesPerSide = 57; // Modules in the QR code pattern itself
|
|
13753
|
+
const totalModuleUnits = estimatedModulesPerSide + 2 * (options.margin || 0); // Total units including margin
|
|
13754
|
+
const moduleSize = canvasElement.width / totalModuleUnits; // Size of one module in canvas pixels
|
|
13755
|
+
// Define desired logo size in terms of modules (must be odd for centering) and calculate in pixels
|
|
13756
|
+
const desiredLogoModules = 15;
|
|
13757
|
+
const logoSize = desiredLogoModules * moduleSize;
|
|
13758
|
+
// Calculate the center of the QR code drawable area (excluding margin pixels)
|
|
13759
|
+
const marginPixels = (options.margin || 0) * moduleSize;
|
|
13760
|
+
const qrCodeDrawableSize = canvasElement.width - 2 * marginPixels;
|
|
13761
|
+
const qrCenterX = marginPixels + qrCodeDrawableSize / 2;
|
|
13762
|
+
const qrCenterY = marginPixels + qrCodeDrawableSize / 2;
|
|
13763
|
+
// Calculate logo position to be centered within the QR code drawable area, snapped to the module grid
|
|
13764
|
+
const logoX = qrCenterX - logoSize / 2;
|
|
13765
|
+
const logoY = qrCenterY - logoSize / 2;
|
|
13766
|
+
// Snap logo position and size to the nearest module boundary for better grid alignment
|
|
13767
|
+
const finalLogoX = Math.round(logoX / moduleSize) * moduleSize;
|
|
13768
|
+
const finalLogoY = Math.round(logoY / moduleSize) * moduleSize;
|
|
13769
|
+
const finalLogoSize = Math.round(logoSize / moduleSize) * moduleSize;
|
|
13770
|
+
// Recalculate hexagon position based on the snapped logo position and size
|
|
13771
|
+
const hexagonPaddingModules = 1; // Padding around the logo in terms of modules
|
|
13772
|
+
const hexagonSize = (desiredLogoModules + 2 * hexagonPaddingModules) * moduleSize; // Hexagon size including padding
|
|
13773
|
+
// Center the hexagon based on the snapped logo position, with padding
|
|
13774
|
+
const hexagonCenterX = finalLogoX + finalLogoSize / 2;
|
|
13775
|
+
const hexagonCenterY = finalLogoY + finalLogoSize / 2;
|
|
13776
|
+
ctx.fillStyle = '#ffffff';
|
|
13777
|
+
ctx.beginPath();
|
|
13778
|
+
// Draw hexagon with corners pointing up
|
|
13779
|
+
for (let i = 0; i < 6; i++) {
|
|
13780
|
+
const angle = (i * Math.PI) / 3 + Math.PI / 6; // Added π/6 to rotate by 30 degrees
|
|
13781
|
+
const x = hexagonCenterX + (hexagonSize / 2) * Math.cos(angle);
|
|
13782
|
+
const y = hexagonCenterY + (hexagonSize / 2) * Math.sin(angle);
|
|
13783
|
+
if (i === 0) {
|
|
13784
|
+
ctx.moveTo(x, y);
|
|
13785
|
+
}
|
|
13786
|
+
else {
|
|
13787
|
+
ctx.lineTo(x, y);
|
|
13788
|
+
}
|
|
13789
|
+
}
|
|
13790
|
+
ctx.closePath();
|
|
13791
|
+
ctx.fill();
|
|
13792
|
+
// Draw logo at the snapped position and size
|
|
13793
|
+
ctx.drawImage(logo, finalLogoX, finalLogoY, finalLogoSize, finalLogoSize);
|
|
13794
|
+
resolve();
|
|
13795
|
+
};
|
|
13796
|
+
// Handle potential logo loading errors
|
|
13797
|
+
logo.onerror = (error) => {
|
|
13798
|
+
console.error('Error loading logo:', error);
|
|
13799
|
+
resolve(); // Resolve anyway to not block QR code rendering
|
|
13800
|
+
};
|
|
13801
|
+
});
|
|
13802
|
+
};
|
|
13803
|
+
/*
|
|
13804
|
+
const handleDownload = async () => {
|
|
13805
|
+
// Create a temporary canvas for high-res QR code
|
|
13806
|
+
const tempCanvas = document.createElement('canvas');
|
|
13807
|
+
const highResOptions: QRCodeRenderersOptions = {
|
|
13808
|
+
...props,
|
|
13809
|
+
color: {
|
|
13810
|
+
dark: '#000080',
|
|
13811
|
+
light: '#FFFFFF',
|
|
13812
|
+
},
|
|
13813
|
+
errorCorrectionLevel: 'H',
|
|
13814
|
+
margin: 1,
|
|
13815
|
+
width: 4096, // Even higher resolution for printing
|
|
13816
|
+
scale: undefined, // Let library determine scale based on width
|
|
13817
|
+
};
|
|
13818
|
+
delete (highResOptions as TODO_any).href;
|
|
13819
|
+
|
|
13820
|
+
// Generate QR code with logo on the temporary canvas
|
|
13821
|
+
await generateQRCode(tempCanvas, highResOptions);
|
|
13822
|
+
|
|
13823
|
+
// Create download link
|
|
13824
|
+
const pngUrl = tempCanvas.toDataURL('image/png').replace('image/png', 'image/octet-stream');
|
|
13825
|
+
const downloadLink = document.createElement('a');
|
|
13826
|
+
downloadLink.href = pngUrl;
|
|
13827
|
+
downloadLink.download = `qrcode-${value
|
|
13828
|
+
.toString()
|
|
13829
|
+
.replace(/[^a-z0-9]/gi, '-')
|
|
13830
|
+
.toLowerCase()}.png`;
|
|
13831
|
+
document.body.appendChild(downloadLink);
|
|
13832
|
+
downloadLink.click();
|
|
13833
|
+
document.body.removeChild(downloadLink);
|
|
13834
|
+
};
|
|
13835
|
+
*/
|
|
13836
|
+
return (jsxRuntime.jsx("div", { className: className, children: jsxRuntime.jsx("canvas", { width: size, height: size, ref: (canvasElement) => {
|
|
13837
|
+
if (!canvasElement) {
|
|
13838
|
+
return;
|
|
13839
|
+
}
|
|
13840
|
+
// Set canvas dimensions if size is specified
|
|
13841
|
+
if (size) {
|
|
13842
|
+
canvasElement.width = size;
|
|
13843
|
+
canvasElement.height = size;
|
|
13844
|
+
}
|
|
13845
|
+
// Display options - keep original size for display
|
|
13846
|
+
const displayOptions = {
|
|
13847
|
+
...props,
|
|
13848
|
+
color: {
|
|
13849
|
+
dark: '#000080',
|
|
13850
|
+
light: '#FFFFFF',
|
|
13851
|
+
},
|
|
13852
|
+
errorCorrectionLevel: 'H',
|
|
13853
|
+
margin: 3,
|
|
13854
|
+
};
|
|
13855
|
+
delete displayOptions.href;
|
|
13856
|
+
delete displayOptions.height; // Remove height as it's not a QRCode option
|
|
13857
|
+
// Generate QR code with logo on the display canvas
|
|
13858
|
+
/* not await */ generateQRCode(canvasElement, displayOptions);
|
|
13859
|
+
} }) }));
|
|
13860
|
+
}
|
|
13861
|
+
|
|
13627
13862
|
/**
|
|
13628
13863
|
* Collect matching CSS texts from document stylesheets for a given class.
|
|
13629
13864
|
* This will skip cross-origin stylesheets (they throw when accessed).
|
|
@@ -13708,12 +13943,12 @@
|
|
|
13708
13943
|
exports.BLOCKY_FLOW = BLOCKY_FLOW;
|
|
13709
13944
|
exports.BOOK_LANGUAGE_VERSION = BOOK_LANGUAGE_VERSION;
|
|
13710
13945
|
exports.BookEditor = BookEditor;
|
|
13946
|
+
exports.BrandedQrCode = BrandedQrCode;
|
|
13711
13947
|
exports.CHAT_SAVE_FORMATS = CHAT_SAVE_FORMATS;
|
|
13712
13948
|
exports.Chat = Chat;
|
|
13713
|
-
exports.CloseIcon = CloseIcon;
|
|
13714
13949
|
exports.DEFAULT_BOOK_EDITOR_HEIGHT = DEFAULT_BOOK_EDITOR_HEIGHT;
|
|
13715
|
-
exports.DEFAULT_BOOK_FONT_CLASS = DEFAULT_BOOK_FONT_CLASS;
|
|
13716
13950
|
exports.FAST_FLOW = FAST_FLOW;
|
|
13951
|
+
exports.GenericQrCode = GenericQrCode;
|
|
13717
13952
|
exports.LlmChat = LlmChat;
|
|
13718
13953
|
exports.MOCKED_CHAT_DELAY_CONFIGS = MOCKED_CHAT_DELAY_CONFIGS;
|
|
13719
13954
|
exports.MarkdownContent = MarkdownContent;
|
|
@@ -13722,6 +13957,7 @@
|
|
|
13722
13957
|
exports.PROMPTBOOK_ENGINE_VERSION = PROMPTBOOK_ENGINE_VERSION;
|
|
13723
13958
|
exports.PauseIcon = PauseIcon;
|
|
13724
13959
|
exports.PlayIcon = PlayIcon;
|
|
13960
|
+
exports.PromptbookQrCode = PromptbookQrCode;
|
|
13725
13961
|
exports.RANDOM_FLOW = RANDOM_FLOW;
|
|
13726
13962
|
exports.ResetIcon = ResetIcon;
|
|
13727
13963
|
exports.SLOW_FLOW = SLOW_FLOW;
|