monacopilot 0.10.9 → 0.10.10

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 CHANGED
@@ -27,7 +27,6 @@
27
27
  - [Max Context Lines](#max-context-lines)
28
28
  - [Copilot Options](#copilot-options)
29
29
  - [Changing the Provider and Model](#changing-the-provider-and-model)
30
- - [Updating Provider and Model at Runtime](#updating-provider-and-model-at-runtime)
31
30
  - [Custom Model](#custom-model)
32
31
  - [Completion Request Options](#completion-request-options)
33
32
  - [Custom Headers](#custom-headers)
@@ -276,17 +275,6 @@ There are other providers and models available. Here is a list:
276
275
  | OpenAI | `gpt-4o`, `gpt-4o-mini`, `o1-preview`, `o1-mini` |
277
276
  | Anthropic | `claude-3.5-Sonnet`, `claude-3-opus`, `claude-3-sonnet`, `claude-3-haiku` |
278
277
 
279
- #### Updating Provider and Model at Runtime
280
-
281
- You can change the provider and model at runtime using the `setModel` method.
282
-
283
- ```javascript
284
- copilot.setModel({
285
- provider: 'anthropic',
286
- model: 'claude-3-haiku',
287
- });
288
- ```
289
-
290
278
  ### Custom Model
291
279
 
292
280
  You can use a custom AI model that isn't built into Monacopilot by setting up a `model` when you create a new Copilot. This feature lets you connect to AI models from other services or your own custom-built models.
package/build/index.d.mts CHANGED
@@ -54,20 +54,6 @@ type CustomCopilotModel = {
54
54
  */
55
55
  transformResponse: CustomCopilotModelTransformResponse;
56
56
  };
57
- type SetModelOptions = {
58
- /**
59
- * The provider to set (e.g., 'openai', 'anthropic', 'groq').
60
- */
61
- provider: CopilotProvider;
62
- /**
63
- * The model to use for copilot AI requests.
64
- * This can be either:
65
- * 1. A predefined model name (e.g. 'claude-3-opus'): Use this option if you want to use a model that is built into Monacopilot.
66
- * If you choose this option, also set the `provider` property to the corresponding provider of the model.
67
- * 2. A custom model configuration object: Use this option if you want to use a AI model from a third-party service or your own custom model.
68
- */
69
- model: CopilotModel | CustomCopilotModel;
70
- };
71
57
  type CustomCopilotModelConfig = (apiKey: string, prompt: {
72
58
  system: string;
73
59
  user: string;
@@ -289,11 +275,6 @@ declare class Copilot {
289
275
  * @returns A promise resolving to the completion response or an error.
290
276
  */
291
277
  complete(request: CompletionRequest): Promise<CompletionResponse>;
292
- /**
293
- * Sets the model and provider for the Copilot.
294
- * @param options - The options for setting the model and provider.
295
- */
296
- setModel({ model, provider }: SetModelOptions): void;
297
278
  }
298
279
 
299
280
  /**
package/build/index.d.ts CHANGED
@@ -54,20 +54,6 @@ type CustomCopilotModel = {
54
54
  */
55
55
  transformResponse: CustomCopilotModelTransformResponse;
56
56
  };
57
- type SetModelOptions = {
58
- /**
59
- * The provider to set (e.g., 'openai', 'anthropic', 'groq').
60
- */
61
- provider: CopilotProvider;
62
- /**
63
- * The model to use for copilot AI requests.
64
- * This can be either:
65
- * 1. A predefined model name (e.g. 'claude-3-opus'): Use this option if you want to use a model that is built into Monacopilot.
66
- * If you choose this option, also set the `provider` property to the corresponding provider of the model.
67
- * 2. A custom model configuration object: Use this option if you want to use a AI model from a third-party service or your own custom model.
68
- */
69
- model: CopilotModel | CustomCopilotModel;
70
- };
71
57
  type CustomCopilotModelConfig = (apiKey: string, prompt: {
72
58
  system: string;
73
59
  user: string;
@@ -289,11 +275,6 @@ declare class Copilot {
289
275
  * @returns A promise resolving to the completion response or an error.
290
276
  */
291
277
  complete(request: CompletionRequest): Promise<CompletionResponse>;
292
- /**
293
- * Sets the model and provider for the Copilot.
294
- * @param options - The options for setting the model and provider.
295
- */
296
- setModel({ model, provider }: SetModelOptions): void;
297
278
  }
298
279
 
299
280
  /**
package/build/index.js CHANGED
@@ -38,7 +38,7 @@ ${c}
38
38
  ${s}
39
39
  ${m}
40
40
  </task>
41
- `};function j(e){return{system:Re(e),user:ye(e)}}var re={"claude-3.5-sonnet":8192,"claude-3-opus":4096,"claude-3-haiku":4096,"claude-3-sonnet":4096};var Oe={createRequestBody:(e,t)=>{let r=e==="o1-preview"||e==="o1-mini"?[{role:"user",content:t.user}]:[{role:"system",content:t.system},{role:"user",content:t.user}];return{model:K(e),temperature:M,messages:r}},createHeaders:e=>({"Content-Type":"application/json",Authorization:`Bearer ${e}`}),parseCompletion:e=>e.choices?.length?e.choices[0].message.content:null},Me={createRequestBody:(e,t)=>({model:K(e),temperature:M,messages:[{role:"system",content:t.system},{role:"user",content:t.user}]}),createHeaders:e=>({"Content-Type":"application/json",Authorization:`Bearer ${e}`}),parseCompletion:e=>e.choices?.length?e.choices[0].message.content:null},Ie={createRequestBody:(e,t)=>({model:K(e),temperature:M,system:t.system,messages:[{role:"user",content:t.user}],max_tokens:be(e)}),createHeaders:e=>({"Content-Type":"application/json","x-api-key":e,"anthropic-version":"2023-06-01"}),parseCompletion:e=>!e.content||typeof e.content!="string"?null:e.content},G={openai:Oe,groq:Me,anthropic:Ie},ne=(e,t,o)=>G[t].createRequestBody(e,o),ie=(e,t)=>G[t].createHeaders(e),se=(e,t)=>G[t].parseCompletion(e),K=e=>X[e],le=e=>Z[e],be=e=>re[e]||4096;var L=class{constructor(t,o={}){if(!t)throw new Error("Please provide an API key.");this.apiKey=t,this.provider=o.provider??z,this.model=o.model??J,this.validateInputs()}validateInputs(){if(!H.includes(this.provider))throw new Error(`The provider "${this.provider}" is not supported. Please choose a supported provider: ${R(H)}. If you're using a custom model, you don't need to specify a provider.`);if(typeof this.model=="string"&&!q[this.provider].includes(this.model)){let t=R(q[this.provider]);throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${t}`)}}async complete(t){let{body:o,options:r}=t,{completionMetadata:n}=o,{headers:i={},customPrompt:l}=r??{},a=j(n),p=l?{...a,...l(n)}:a,s=le(this.provider),m,u=ie(this.apiKey,this.provider);if(typeof this.model=="object"&&"config"in this.model){let c=this.model.config(this.apiKey,p);s=c.endpoint??s,m=c.body??{},u={...u,...c.headers}}else m=ne(this.model,this.provider,p);u={...u,...i};try{let c=await v.POST(s,m,{headers:u}),d;if(typeof this.model=="object"&&"transformResponse"in this.model){let C=this.model.transformResponse(c);d={completion:C.text??C.completion}}else d={completion:se(c,this.provider)};return d}catch(c){return{error:g(c,"COPILOT_COMPLETION_FETCH_ERROR").message,completion:null}}}setModel({model:t,provider:o}){this.model=t,this.provider=o,this.validateInputs()}};var _=class e{constructor(t){this.formattedCompletion="";this.formattedCompletion=t}static create(t){return new e(t)}setCompletion(t){return this.formattedCompletion=t,this}removeInvalidLineBreaks(){return this.formattedCompletion=this.formattedCompletion.trimEnd(),this}removeMarkdownCodeSyntax(){return this.formattedCompletion=this.removeMarkdownCodeBlocks(this.formattedCompletion),this}removeMarkdownCodeBlocks(t){let o=/```[\s\S]*?```/g,r=t,n;for(;(n=o.exec(t))!==null;){let i=n[0],l=i.split(`
41
+ `};function j(e){return{system:Re(e),user:ye(e)}}var re={"claude-3.5-sonnet":8192,"claude-3-opus":4096,"claude-3-haiku":4096,"claude-3-sonnet":4096};var Oe={createRequestBody:(e,t)=>{let r=e==="o1-preview"||e==="o1-mini"?[{role:"user",content:t.user}]:[{role:"system",content:t.system},{role:"user",content:t.user}];return{model:K(e),temperature:M,messages:r}},createHeaders:e=>({"Content-Type":"application/json",Authorization:`Bearer ${e}`}),parseCompletion:e=>e.choices?.length?e.choices[0].message.content:null},Me={createRequestBody:(e,t)=>({model:K(e),temperature:M,messages:[{role:"system",content:t.system},{role:"user",content:t.user}]}),createHeaders:e=>({"Content-Type":"application/json",Authorization:`Bearer ${e}`}),parseCompletion:e=>e.choices?.length?e.choices[0].message.content:null},Ie={createRequestBody:(e,t)=>({model:K(e),temperature:M,system:t.system,messages:[{role:"user",content:t.user}],max_tokens:be(e)}),createHeaders:e=>({"Content-Type":"application/json","x-api-key":e,"anthropic-version":"2023-06-01"}),parseCompletion:e=>!e.content||typeof e.content!="string"?null:e.content},G={openai:Oe,groq:Me,anthropic:Ie},ne=(e,t,o)=>G[t].createRequestBody(e,o),ie=(e,t)=>G[t].createHeaders(e),se=(e,t)=>G[t].parseCompletion(e),K=e=>X[e],le=e=>Z[e],be=e=>re[e]||4096;var L=class{constructor(t,o={}){if(!t)throw new Error("Please provide an API key.");this.apiKey=t,this.provider=o.provider??z,this.model=o.model??J,this.validateInputs()}validateInputs(){if(!H.includes(this.provider))throw new Error(`The provider "${this.provider}" is not supported. Please choose a supported provider: ${R(H)}. If you're using a custom model, you don't need to specify a provider.`);if(typeof this.model=="string"&&!q[this.provider].includes(this.model)){let t=R(q[this.provider]);throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${t}`)}}async complete(t){let{body:o,options:r}=t,{completionMetadata:n}=o,{headers:i={},customPrompt:l}=r??{},a=j(n),p=l?{...a,...l(n)}:a,s=le(this.provider),m,u=ie(this.apiKey,this.provider);if(typeof this.model=="object"&&"config"in this.model){let c=this.model.config(this.apiKey,p);s=c.endpoint??s,m=c.body??{},u={...u,...c.headers}}else m=ne(this.model,this.provider,p);u={...u,...i};try{let c=await v.POST(s,m,{headers:u}),d;if(typeof this.model=="object"&&"transformResponse"in this.model){let C=this.model.transformResponse(c);d={completion:C.text??C.completion}}else d={completion:se(c,this.provider)};return d}catch(c){return{error:g(c,"COPILOT_COMPLETION_FETCH_ERROR").message,completion:null}}}};var _=class e{constructor(t){this.formattedCompletion="";this.formattedCompletion=t}static create(t){return new e(t)}setCompletion(t){return this.formattedCompletion=t,this}removeInvalidLineBreaks(){return this.formattedCompletion=this.formattedCompletion.trimEnd(),this}removeMarkdownCodeSyntax(){return this.formattedCompletion=this.removeMarkdownCodeBlocks(this.formattedCompletion),this}removeMarkdownCodeBlocks(t){let o=/```[\s\S]*?```/g,r=t,n;for(;(n=o.exec(t))!==null;){let i=n[0],l=i.split(`
42
42
  `).slice(1,-1).join(`
43
43
  `);r=r.replace(i,l)}return r.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
44
44
 
package/build/index.mjs CHANGED
@@ -38,7 +38,7 @@ ${c}
38
38
  ${s}
39
39
  ${m}
40
40
  </task>
41
- `};function U(e){return{system:Ce(e),user:ge(e)}}var te={"claude-3.5-sonnet":8192,"claude-3-opus":4096,"claude-3-haiku":4096,"claude-3-sonnet":4096};var he={createRequestBody:(e,t)=>{let r=e==="o1-preview"||e==="o1-mini"?[{role:"user",content:t.user}]:[{role:"system",content:t.system},{role:"user",content:t.user}];return{model:j(e),temperature:M,messages:r}},createHeaders:e=>({"Content-Type":"application/json",Authorization:`Bearer ${e}`}),parseCompletion:e=>e.choices?.length?e.choices[0].message.content:null},fe={createRequestBody:(e,t)=>({model:j(e),temperature:M,messages:[{role:"system",content:t.system},{role:"user",content:t.user}]}),createHeaders:e=>({"Content-Type":"application/json",Authorization:`Bearer ${e}`}),parseCompletion:e=>e.choices?.length?e.choices[0].message.content:null},Ee={createRequestBody:(e,t)=>({model:j(e),temperature:M,system:t.system,messages:[{role:"user",content:t.user}],max_tokens:Pe(e)}),createHeaders:e=>({"Content-Type":"application/json","x-api-key":e,"anthropic-version":"2023-06-01"}),parseCompletion:e=>!e.content||typeof e.content!="string"?null:e.content},V={openai:he,groq:fe,anthropic:Ee},oe=(e,t,o)=>V[t].createRequestBody(e,o),re=(e,t)=>V[t].createHeaders(e),ne=(e,t)=>V[t].parseCompletion(e),j=e=>W[e],ie=e=>J[e],Pe=e=>te[e]||4096;var G=class{constructor(t,o={}){if(!t)throw new Error("Please provide an API key.");this.apiKey=t,this.provider=o.provider??X,this.model=o.model??Y,this.validateInputs()}validateInputs(){if(!B.includes(this.provider))throw new Error(`The provider "${this.provider}" is not supported. Please choose a supported provider: ${R(B)}. If you're using a custom model, you don't need to specify a provider.`);if(typeof this.model=="string"&&!k[this.provider].includes(this.model)){let t=R(k[this.provider]);throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${t}`)}}async complete(t){let{body:o,options:r}=t,{completionMetadata:n}=o,{headers:i={},customPrompt:l}=r??{},a=U(n),p=l?{...a,...l(n)}:a,s=ie(this.provider),m,u=re(this.apiKey,this.provider);if(typeof this.model=="object"&&"config"in this.model){let c=this.model.config(this.apiKey,p);s=c.endpoint??s,m=c.body??{},u={...u,...c.headers}}else m=oe(this.model,this.provider,p);u={...u,...i};try{let c=await v.POST(s,m,{headers:u}),d;if(typeof this.model=="object"&&"transformResponse"in this.model){let C=this.model.transformResponse(c);d={completion:C.text??C.completion}}else d={completion:ne(c,this.provider)};return d}catch(c){return{error:g(c,"COPILOT_COMPLETION_FETCH_ERROR").message,completion:null}}}setModel({model:t,provider:o}){this.model=t,this.provider=o,this.validateInputs()}};var L=class e{constructor(t){this.formattedCompletion="";this.formattedCompletion=t}static create(t){return new e(t)}setCompletion(t){return this.formattedCompletion=t,this}removeInvalidLineBreaks(){return this.formattedCompletion=this.formattedCompletion.trimEnd(),this}removeMarkdownCodeSyntax(){return this.formattedCompletion=this.removeMarkdownCodeBlocks(this.formattedCompletion),this}removeMarkdownCodeBlocks(t){let o=/```[\s\S]*?```/g,r=t,n;for(;(n=o.exec(t))!==null;){let i=n[0],l=i.split(`
41
+ `};function U(e){return{system:Ce(e),user:ge(e)}}var te={"claude-3.5-sonnet":8192,"claude-3-opus":4096,"claude-3-haiku":4096,"claude-3-sonnet":4096};var he={createRequestBody:(e,t)=>{let r=e==="o1-preview"||e==="o1-mini"?[{role:"user",content:t.user}]:[{role:"system",content:t.system},{role:"user",content:t.user}];return{model:j(e),temperature:M,messages:r}},createHeaders:e=>({"Content-Type":"application/json",Authorization:`Bearer ${e}`}),parseCompletion:e=>e.choices?.length?e.choices[0].message.content:null},fe={createRequestBody:(e,t)=>({model:j(e),temperature:M,messages:[{role:"system",content:t.system},{role:"user",content:t.user}]}),createHeaders:e=>({"Content-Type":"application/json",Authorization:`Bearer ${e}`}),parseCompletion:e=>e.choices?.length?e.choices[0].message.content:null},Ee={createRequestBody:(e,t)=>({model:j(e),temperature:M,system:t.system,messages:[{role:"user",content:t.user}],max_tokens:Pe(e)}),createHeaders:e=>({"Content-Type":"application/json","x-api-key":e,"anthropic-version":"2023-06-01"}),parseCompletion:e=>!e.content||typeof e.content!="string"?null:e.content},V={openai:he,groq:fe,anthropic:Ee},oe=(e,t,o)=>V[t].createRequestBody(e,o),re=(e,t)=>V[t].createHeaders(e),ne=(e,t)=>V[t].parseCompletion(e),j=e=>W[e],ie=e=>J[e],Pe=e=>te[e]||4096;var G=class{constructor(t,o={}){if(!t)throw new Error("Please provide an API key.");this.apiKey=t,this.provider=o.provider??X,this.model=o.model??Y,this.validateInputs()}validateInputs(){if(!B.includes(this.provider))throw new Error(`The provider "${this.provider}" is not supported. Please choose a supported provider: ${R(B)}. If you're using a custom model, you don't need to specify a provider.`);if(typeof this.model=="string"&&!k[this.provider].includes(this.model)){let t=R(k[this.provider]);throw new Error(`Model "${this.model}" is not supported by the "${this.provider}" provider. Supported models: ${t}`)}}async complete(t){let{body:o,options:r}=t,{completionMetadata:n}=o,{headers:i={},customPrompt:l}=r??{},a=U(n),p=l?{...a,...l(n)}:a,s=ie(this.provider),m,u=re(this.apiKey,this.provider);if(typeof this.model=="object"&&"config"in this.model){let c=this.model.config(this.apiKey,p);s=c.endpoint??s,m=c.body??{},u={...u,...c.headers}}else m=oe(this.model,this.provider,p);u={...u,...i};try{let c=await v.POST(s,m,{headers:u}),d;if(typeof this.model=="object"&&"transformResponse"in this.model){let C=this.model.transformResponse(c);d={completion:C.text??C.completion}}else d={completion:ne(c,this.provider)};return d}catch(c){return{error:g(c,"COPILOT_COMPLETION_FETCH_ERROR").message,completion:null}}}};var L=class e{constructor(t){this.formattedCompletion="";this.formattedCompletion=t}static create(t){return new e(t)}setCompletion(t){return this.formattedCompletion=t,this}removeInvalidLineBreaks(){return this.formattedCompletion=this.formattedCompletion.trimEnd(),this}removeMarkdownCodeSyntax(){return this.formattedCompletion=this.removeMarkdownCodeBlocks(this.formattedCompletion),this}removeMarkdownCodeBlocks(t){let o=/```[\s\S]*?```/g,r=t,n;for(;(n=o.exec(t))!==null;){let i=n[0],l=i.split(`
42
42
  `).slice(1,-1).join(`
43
43
  `);r=r.replace(i,l)}return r.trim()}removeExcessiveNewlines(){return this.formattedCompletion=this.formattedCompletion.replace(/\n{3,}/g,`
44
44
 
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "monacopilot",
3
- "version": "0.10.9",
3
+ "version": "0.10.10",
4
4
  "description": "AI auto-completion plugin for Monaco Editor",
5
5
  "main": "./build/index.js",
6
6
  "module": "./build/index.mjs",