From 6efbdd9448e1f4df056021f3d44b2ec41f7ddb8a Mon Sep 17 00:00:00 2001 From: Nathan Courtney Date: Thu, 7 Sep 2023 16:54:38 +0000 Subject: [PATCH] Release 1.3.0 --- main.js | 1014 +++++++++++++++++++++++++++++++++++++++++++------ manifest.json | 2 +- styles.css | 2 +- 3 files changed, 895 insertions(+), 123 deletions(-) diff --git a/main.js b/main.js index 0a6eb0c..18eeec7 100644 --- a/main.js +++ b/main.js @@ -2717,7 +2717,7 @@ __export(main_exports, { theme: () => theme }); module.exports = __toCommonJS(main_exports); -var import_obsidian22 = require("obsidian"); +var import_obsidian23 = require("obsidian"); // PiecesSDK/connector/runtime.ts var BASE_PATH = "http://localhost:1000".replace(/\/+$/, ""); @@ -8564,7 +8564,13 @@ function TrackedAssetEventIdentifierDescriptionPairsFromJSONTyped2(json, ignoreD "suggestedAssetReferenced": !exists(json, "suggested_asset_referenced") ? void 0 : json["suggested_asset_referenced"], "searchedAssetReferenced": !exists(json, "searched_asset_referenced") ? void 0 : json["searched_asset_referenced"], "assetReferenced": !exists(json, "asset_referenced") ? void 0 : json["asset_referenced"], - "activityAssetReferenced": !exists(json, "activity_asset_referenced") ? void 0 : json["activity_asset_referenced"] + "activityAssetReferenced": !exists(json, "activity_asset_referenced") ? void 0 : json["activity_asset_referenced"], + "assetAnnotationAdded": !exists(json, "asset_annotation_added") ? void 0 : json["asset_annotation_added"], + "assetAnnotationDeleted": !exists(json, "asset_annotation_deleted") ? void 0 : json["asset_annotation_deleted"], + "assetAnnotationUpdated": !exists(json, "asset_annotation_updated") ? void 0 : json["asset_annotation_updated"], + "assetHintAdded": !exists(json, "asset_hint_added") ? void 0 : json["asset_hint_added"], + "assetHintDeleted": !exists(json, "asset_hint_deleted") ? void 0 : json["asset_hint_deleted"], + "assetHintUpdated": !exists(json, "asset_hint_updated") ? void 0 : json["asset_hint_updated"] }; } function TrackedAssetEventIdentifierDescriptionPairsToJSON(value) { @@ -8602,7 +8608,13 @@ function TrackedAssetEventIdentifierDescriptionPairsToJSON(value) { "suggested_asset_referenced": value.suggestedAssetReferenced, "searched_asset_referenced": value.searchedAssetReferenced, "asset_referenced": value.assetReferenced, - "activity_asset_referenced": value.activityAssetReferenced + "activity_asset_referenced": value.activityAssetReferenced, + "asset_annotation_added": value.assetAnnotationAdded, + "asset_annotation_deleted": value.assetAnnotationDeleted, + "asset_annotation_updated": value.assetAnnotationUpdated, + "asset_hint_added": value.assetHintAdded, + "asset_hint_deleted": value.assetHintDeleted, + "asset_hint_updated": value.assetHintUpdated }; } @@ -8623,7 +8635,9 @@ function TrackedAssetEventMetadataFromJSONTyped2(json, ignoreDiscriminator) { "person": !exists(json, "person") ? void 0 : ReferencedPersonFromJSON(json["person"]), "sensitive": !exists(json, "sensitive") ? void 0 : ReferencedSensitiveFromJSON(json["sensitive"]), "share": !exists(json, "share") ? void 0 : ReferencedShareFromJSON(json["share"]), - "search": !exists(json, "search") ? void 0 : TrackedAssetsEventSearchMetadataFromJSON(json["search"]) + "search": !exists(json, "search") ? void 0 : TrackedAssetsEventSearchMetadataFromJSON(json["search"]), + "annotation": !exists(json, "annotation") ? void 0 : ReferencedAnnotationFromJSON(json["annotation"]), + "hint": !exists(json, "hint") ? void 0 : ReferencedHintFromJSON(json["hint"]) }; } function TrackedAssetEventMetadataToJSON(value) { @@ -8642,7 +8656,9 @@ function TrackedAssetEventMetadataToJSON(value) { "person": ReferencedPersonToJSON(value.person), "sensitive": ReferencedSensitiveToJSON(value.sensitive), "share": ReferencedShareToJSON(value.share), - "search": TrackedAssetsEventSearchMetadataToJSON(value.search) + "search": TrackedAssetsEventSearchMetadataToJSON(value.search), + "annotation": ReferencedAnnotationToJSON(value.annotation), + "hint": ReferencedHintToJSON(value.hint) }; } @@ -9911,14 +9927,14 @@ function AnnotationToJSON2(value) { } // PiecesSDK/core/models/AnnotationTypeEnum.ts -var AnnotationTypeEnum5 = /* @__PURE__ */ ((AnnotationTypeEnum12) => { - AnnotationTypeEnum12["Description"] = "DESCRIPTION"; - AnnotationTypeEnum12["Comment"] = "COMMENT"; - AnnotationTypeEnum12["Documentation"] = "DOCUMENTATION"; - AnnotationTypeEnum12["Summary"] = "SUMMARY"; - AnnotationTypeEnum12["Explanation"] = "EXPLANATION"; - AnnotationTypeEnum12["GitCommit"] = "GIT_COMMIT"; - return AnnotationTypeEnum12; +var AnnotationTypeEnum5 = /* @__PURE__ */ ((AnnotationTypeEnum14) => { + AnnotationTypeEnum14["Description"] = "DESCRIPTION"; + AnnotationTypeEnum14["Comment"] = "COMMENT"; + AnnotationTypeEnum14["Documentation"] = "DOCUMENTATION"; + AnnotationTypeEnum14["Summary"] = "SUMMARY"; + AnnotationTypeEnum14["Explanation"] = "EXPLANATION"; + AnnotationTypeEnum14["GitCommit"] = "GIT_COMMIT"; + return AnnotationTypeEnum14; })(AnnotationTypeEnum5 || {}); function AnnotationTypeEnumFromJSON2(json) { return AnnotationTypeEnumFromJSONTyped6(json, false); @@ -10083,6 +10099,90 @@ function AssetToJSON2(value) { }; } +// PiecesSDK/core/models/AssetFilter.ts +function AssetFilterToJSON(value) { + if (value === void 0) { + return void 0; + } + if (value === null) { + return null; + } + return { + "schema": EmbeddedModelSchemaToJSON2(value.schema), + "classification": ClassificationSpecificEnumToJSON2(value.classification), + "tags": value.tags, + "websites": value.websites, + "persons": value.persons, + "phrase": AssetFilterPhraseToJSON(value.phrase), + "created": AssetFilterTimestampToJSON(value.created), + "updated": AssetFilterTimestampToJSON(value.updated), + "operations": AssetFiltersToJSON(value.operations) + }; +} + +// PiecesSDK/core/models/AssetFilterPhrase.ts +function AssetFilterPhraseToJSON(value) { + if (value === void 0) { + return void 0; + } + if (value === null) { + return null; + } + return { + "schema": EmbeddedModelSchemaToJSON2(value.schema), + "value": value.value, + "annotation": value.annotation, + "title": value.title, + "content": value.content, + "options": AssetFilterPhraseOptionsToJSON(value.options) + }; +} + +// PiecesSDK/core/models/AssetFilterPhraseOptions.ts +function AssetFilterPhraseOptionsToJSON(value) { + if (value === void 0) { + return void 0; + } + if (value === null) { + return null; + } + return { + "schema": EmbeddedModelSchemaToJSON2(value.schema), + "annotation": AnnotationTypeEnumToJSON2(value.annotation) + }; +} + +// PiecesSDK/core/models/AssetFilterTimestamp.ts +function AssetFilterTimestampToJSON(value) { + if (value === void 0) { + return void 0; + } + if (value === null) { + return null; + } + return { + "schema": EmbeddedModelSchemaToJSON2(value.schema), + "from": GroupedTimestampToJSON2(value.from), + "to": GroupedTimestampToJSON2(value.to), + "between": value.between + }; +} + +// PiecesSDK/core/models/AssetFilters.ts +function AssetFiltersToJSON(value) { + if (value === void 0) { + return void 0; + } + if (value === null) { + return null; + } + return { + "schema": EmbeddedModelSchemaToJSON2(value.schema), + "iterable": value.iterable.map(AssetFilterToJSON), + "type": FilterOperationTypeEnumToJSON(value.type) + }; +} + // PiecesSDK/core/models/AssetFormats.ts function AssetFormatsFromJSON2(json) { return AssetFormatsFromJSONTyped4(json, false); @@ -10126,6 +10226,20 @@ function AssetReclassificationToJSON(value) { }; } +// PiecesSDK/core/models/AssetSearchSpace.ts +function AssetSearchSpaceToJSON(value) { + if (value === void 0) { + return void 0; + } + if (value === null) { + return null; + } + return { + "schema": EmbeddedModelSchemaToJSON2(value.schema), + "identifers": FlattenedAssetsToJSON2(value.identifers) + }; +} + // PiecesSDK/core/models/Assets.ts function AssetsFromJSON2(json) { return AssetsFromJSONTyped5(json, false); @@ -10154,6 +10268,37 @@ function AssetsToJSON2(value) { }; } +// PiecesSDK/core/models/AssetsSearchWithFiltersInput.ts +function AssetsSearchWithFiltersInputToJSON(value) { + if (value === void 0) { + return void 0; + } + if (value === null) { + return null; + } + return { + "schema": EmbeddedModelSchemaToJSON2(value.schema), + "query": value.query, + "space": AssetSearchSpaceToJSON(value.space), + "filters": AssetFiltersToJSON(value.filters), + "casing": value.casing + }; +} + +// PiecesSDK/core/models/AssetsSearchWithFiltersOutput.ts +function AssetsSearchWithFiltersOutputFromJSON(json) { + return AssetsSearchWithFiltersOutputFromJSONTyped(json, false); +} +function AssetsSearchWithFiltersOutputFromJSONTyped(json, ignoreDiscriminator) { + if (json === void 0 || json === null) { + return json; + } + return { + "schema": !exists2(json, "schema") ? void 0 : EmbeddedModelSchemaFromJSON2(json["schema"]), + "results": SearchedAssetsFromJSON2(json["results"]) + }; +} + // PiecesSDK/core/models/Auth0Identity.ts function Auth0IdentityToJSON(value) { if (value === void 0) { @@ -10382,9 +10527,9 @@ function ClassificationRenderingEnumToJSON2(value) { // PiecesSDK/core/models/ClassificationSpecificEnum.ts function ClassificationSpecificEnumFromJSON2(json) { - return ClassificationSpecificEnumFromJSONTyped8(json, false); + return ClassificationSpecificEnumFromJSONTyped9(json, false); } -function ClassificationSpecificEnumFromJSONTyped8(json, ignoreDiscriminator) { +function ClassificationSpecificEnumFromJSONTyped9(json, ignoreDiscriminator) { return json; } function ClassificationSpecificEnumToJSON2(value) { @@ -10647,9 +10792,9 @@ function EdgesToJSON2(value) { // PiecesSDK/core/models/EmbeddedModelSchema.ts function EmbeddedModelSchemaFromJSON2(json) { - return EmbeddedModelSchemaFromJSONTyped219(json, false); + return EmbeddedModelSchemaFromJSONTyped227(json, false); } -function EmbeddedModelSchemaFromJSONTyped219(json, ignoreDiscriminator) { +function EmbeddedModelSchemaFromJSONTyped227(json, ignoreDiscriminator) { if (json === void 0 || json === null) { return json; } @@ -11011,6 +11156,11 @@ function FileMetadataToJSON2(value) { }; } +// PiecesSDK/core/models/FilterOperationTypeEnum.ts +function FilterOperationTypeEnumToJSON(value) { + return value; +} + // PiecesSDK/core/models/FlattenedActivities.ts function FlattenedActivitiesFromJSON2(json) { return FlattenedActivitiesFromJSONTyped4(json, false); @@ -11267,9 +11417,9 @@ function FlattenedAssetToJSON2(value) { // PiecesSDK/core/models/FlattenedAssets.ts function FlattenedAssetsFromJSON2(json) { - return FlattenedAssetsFromJSONTyped7(json, false); + return FlattenedAssetsFromJSONTyped8(json, false); } -function FlattenedAssetsFromJSONTyped7(json, ignoreDiscriminator) { +function FlattenedAssetsFromJSONTyped8(json, ignoreDiscriminator) { if (json === void 0 || json === null) { return json; } @@ -12512,9 +12662,9 @@ function GraphicalSVGStatisticsToJSON2(value) { // PiecesSDK/core/models/GroupedTimestamp.ts function GroupedTimestampFromJSON2(json) { - return GroupedTimestampFromJSONTyped55(json, false); + return GroupedTimestampFromJSONTyped56(json, false); } -function GroupedTimestampFromJSONTyped55(json, ignoreDiscriminator) { +function GroupedTimestampFromJSONTyped56(json, ignoreDiscriminator) { if (json === void 0 || json === null) { return json; } @@ -13456,6 +13606,46 @@ function QGPTRepromptOutputFromJSONTyped(json, ignoreDiscriminator) { }; } +// PiecesSDK/core/models/QGPTStreamEnum.ts +function QGPTStreamEnumFromJSON(json) { + return QGPTStreamEnumFromJSONTyped(json, false); +} +function QGPTStreamEnumFromJSONTyped(json, ignoreDiscriminator) { + return json; +} + +// PiecesSDK/core/models/QGPTStreamInput.ts +function QGPTStreamInputToJSON(value) { + if (value === void 0) { + return void 0; + } + if (value === null) { + return null; + } + return { + "relevance": QGPTRelevanceInputToJSON(value.relevance), + "question": QGPTQuestionInputToJSON(value.question), + "request": value.request, + "stop": value.stop + }; +} + +// PiecesSDK/core/models/QGPTStreamOutput.ts +function QGPTStreamOutputFromJSON(json) { + return QGPTStreamOutputFromJSONTyped(json, false); +} +function QGPTStreamOutputFromJSONTyped(json, ignoreDiscriminator) { + if (json === void 0 || json === null) { + return json; + } + return { + "request": !exists2(json, "request") ? void 0 : json["request"], + "relevance": !exists2(json, "relevance") ? void 0 : QGPTRelevanceOutputFromJSON(json["relevance"]), + "question": !exists2(json, "question") ? void 0 : QGPTQuestionOutputFromJSON(json["question"]), + "status": !exists2(json, "status") ? void 0 : QGPTStreamEnumFromJSON(json["status"]) + }; +} + // PiecesSDK/core/models/Recipients.ts function RecipientsFromJSON2(json) { return RecipientsFromJSONTyped6(json, false); @@ -13512,9 +13702,9 @@ function ReferencedActivityToJSON2(value) { // PiecesSDK/core/models/ReferencedAnnotation.ts function ReferencedAnnotationFromJSON2(json) { - return ReferencedAnnotationFromJSONTyped4(json, false); + return ReferencedAnnotationFromJSONTyped5(json, false); } -function ReferencedAnnotationFromJSONTyped4(json, ignoreDiscriminator) { +function ReferencedAnnotationFromJSONTyped5(json, ignoreDiscriminator) { if (json === void 0 || json === null) { return json; } @@ -13624,9 +13814,9 @@ function ReferencedFormatToJSON2(value) { // PiecesSDK/core/models/ReferencedHint.ts function ReferencedHintFromJSON2(json) { - return ReferencedHintFromJSONTyped4(json, false); + return ReferencedHintFromJSONTyped5(json, false); } -function ReferencedHintFromJSONTyped4(json, ignoreDiscriminator) { +function ReferencedHintFromJSONTyped5(json, ignoreDiscriminator) { if (json === void 0 || json === null) { return json; } @@ -13984,9 +14174,9 @@ function SearchedAssetFromJSONTyped3(json, ignoreDiscriminator) { // PiecesSDK/core/models/SearchedAssets.ts function SearchedAssetsFromJSON2(json) { - return SearchedAssetsFromJSONTyped3(json, false); + return SearchedAssetsFromJSONTyped4(json, false); } -function SearchedAssetsFromJSONTyped3(json, ignoreDiscriminator) { +function SearchedAssetsFromJSONTyped4(json, ignoreDiscriminator) { if (json === void 0 || json === null) { return json; } @@ -16424,7 +16614,13 @@ function TrackedAssetEventIdentifierDescriptionPairsFromJSONTyped4(json, ignoreD "suggestedAssetReferenced": !exists2(json, "suggested_asset_referenced") ? void 0 : json["suggested_asset_referenced"], "searchedAssetReferenced": !exists2(json, "searched_asset_referenced") ? void 0 : json["searched_asset_referenced"], "assetReferenced": !exists2(json, "asset_referenced") ? void 0 : json["asset_referenced"], - "activityAssetReferenced": !exists2(json, "activity_asset_referenced") ? void 0 : json["activity_asset_referenced"] + "activityAssetReferenced": !exists2(json, "activity_asset_referenced") ? void 0 : json["activity_asset_referenced"], + "assetAnnotationAdded": !exists2(json, "asset_annotation_added") ? void 0 : json["asset_annotation_added"], + "assetAnnotationDeleted": !exists2(json, "asset_annotation_deleted") ? void 0 : json["asset_annotation_deleted"], + "assetAnnotationUpdated": !exists2(json, "asset_annotation_updated") ? void 0 : json["asset_annotation_updated"], + "assetHintAdded": !exists2(json, "asset_hint_added") ? void 0 : json["asset_hint_added"], + "assetHintDeleted": !exists2(json, "asset_hint_deleted") ? void 0 : json["asset_hint_deleted"], + "assetHintUpdated": !exists2(json, "asset_hint_updated") ? void 0 : json["asset_hint_updated"] }; } function TrackedAssetEventIdentifierDescriptionPairsToJSON2(value) { @@ -16462,7 +16658,13 @@ function TrackedAssetEventIdentifierDescriptionPairsToJSON2(value) { "suggested_asset_referenced": value.suggestedAssetReferenced, "searched_asset_referenced": value.searchedAssetReferenced, "asset_referenced": value.assetReferenced, - "activity_asset_referenced": value.activityAssetReferenced + "activity_asset_referenced": value.activityAssetReferenced, + "asset_annotation_added": value.assetAnnotationAdded, + "asset_annotation_deleted": value.assetAnnotationDeleted, + "asset_annotation_updated": value.assetAnnotationUpdated, + "asset_hint_added": value.assetHintAdded, + "asset_hint_deleted": value.assetHintDeleted, + "asset_hint_updated": value.assetHintUpdated }; } @@ -16483,7 +16685,9 @@ function TrackedAssetEventMetadataFromJSONTyped4(json, ignoreDiscriminator) { "person": !exists2(json, "person") ? void 0 : ReferencedPersonFromJSON2(json["person"]), "sensitive": !exists2(json, "sensitive") ? void 0 : ReferencedSensitiveFromJSON2(json["sensitive"]), "share": !exists2(json, "share") ? void 0 : ReferencedShareFromJSON2(json["share"]), - "search": !exists2(json, "search") ? void 0 : TrackedAssetsEventSearchMetadataFromJSON2(json["search"]) + "search": !exists2(json, "search") ? void 0 : TrackedAssetsEventSearchMetadataFromJSON2(json["search"]), + "annotation": !exists2(json, "annotation") ? void 0 : ReferencedAnnotationFromJSON2(json["annotation"]), + "hint": !exists2(json, "hint") ? void 0 : ReferencedHintFromJSON2(json["hint"]) }; } function TrackedAssetEventMetadataToJSON2(value) { @@ -16502,7 +16706,9 @@ function TrackedAssetEventMetadataToJSON2(value) { "person": ReferencedPersonToJSON2(value.person), "sensitive": ReferencedSensitiveToJSON2(value.sensitive), "share": ReferencedShareToJSON2(value.share), - "search": TrackedAssetsEventSearchMetadataToJSON2(value.search) + "search": TrackedAssetsEventSearchMetadataToJSON2(value.search), + "annotation": ReferencedAnnotationToJSON2(value.annotation), + "hint": ReferencedHintToJSON2(value.hint) }; } @@ -17651,7 +17857,7 @@ var AssetsApi = class extends BaseAPI2 { } /** * This function will search your pieces and will return Assets(the results) based on your query! Eventually** /assets/search?query=string [GET] Scoped to Asset Currently just send along your query in the body. Required to pass searchable_tags (csv of tags) or a query string. if a query is passed we will run through fuzzy search. if searchable_tags are passed we will run through tag_based_search. if neither are passed in we will return a 500. - * /assets/search?query=string + * /assets/search?query=string [GET] */ async assetsSearchAssetsRaw(requestParameters) { const queryParameters = {}; @@ -17678,12 +17884,43 @@ var AssetsApi = class extends BaseAPI2 { } /** * This function will search your pieces and will return Assets(the results) based on your query! Eventually** /assets/search?query=string [GET] Scoped to Asset Currently just send along your query in the body. Required to pass searchable_tags (csv of tags) or a query string. if a query is passed we will run through fuzzy search. if searchable_tags are passed we will run through tag_based_search. if neither are passed in we will return a 500. - * /assets/search?query=string + * /assets/search?query=string [GET] */ async assetsSearchAssets(requestParameters) { const response = await this.assetsSearchAssetsRaw(requestParameters); return await response.value(); } + /** + * This function will search your pieces and will return Assets(the results) based on your query! /assets/search [POST] Scoped to Asset Currently just send along your query in the body. if a query is passed we will run through fuzzy search. The Post Body will also accept a search space, being either a list of uuids.(in the future potentially Seeds.) The Post Body will also accept optional filters, which is an iterable of filters all will be AND operations for now. + * /assets/search [POST] + */ + async assetsSearchWithFiltersRaw(requestParameters) { + const queryParameters = {}; + if (requestParameters.transferables !== void 0) { + queryParameters["transferables"] = requestParameters.transferables; + } + if (requestParameters.pseudo !== void 0) { + queryParameters["pseudo"] = requestParameters.pseudo; + } + const headerParameters = {}; + headerParameters["Content-Type"] = "application/json"; + const response = await this.request({ + path: `/assets/search`, + method: "POST", + headers: headerParameters, + query: queryParameters, + body: AssetsSearchWithFiltersInputToJSON(requestParameters.assetsSearchWithFiltersInput) + }); + return new JSONApiResponse2(response, (jsonValue) => AssetsSearchWithFiltersOutputFromJSON(jsonValue)); + } + /** + * This function will search your pieces and will return Assets(the results) based on your query! /assets/search [POST] Scoped to Asset Currently just send along your query in the body. if a query is passed we will run through fuzzy search. The Post Body will also accept a search space, being either a list of uuids.(in the future potentially Seeds.) The Post Body will also accept optional filters, which is an iterable of filters all will be AND operations for now. + * /assets/search [POST] + */ + async assetsSearchWithFilters(requestParameters) { + const response = await this.assetsSearchWithFiltersRaw(requestParameters); + return await response.value(); + } /** * Get all of the users Assets. * /assets [GET] Scoped to Assets @@ -18329,6 +18566,31 @@ var QGPTApi = class extends BaseAPI2 { const response = await this.personsRelatedRaw(requestParameters); return await response.value(); } + /** + * This is a version of qGPT stream that will stream the inputs. This will handle relevance. This will handle question. This will throw an error if both are passed in. That being said if you want to utalize question && relevant, you can get stream results by passing in relevance with options.question:true. This will handle multiple conversations. This is a Websocket. + * /qgpt/stream [GET] + */ + async qgptStreamRaw(requestParameters) { + const queryParameters = {}; + const headerParameters = {}; + headerParameters["Content-Type"] = "application/json"; + const response = await this.request({ + path: `/qgpt/stream`, + method: "GET", + headers: headerParameters, + query: queryParameters, + body: QGPTStreamInputToJSON(requestParameters.qGPTStreamInput) + }); + return new JSONApiResponse2(response, (jsonValue) => QGPTStreamOutputFromJSON(jsonValue)); + } + /** + * This is a version of qGPT stream that will stream the inputs. This will handle relevance. This will handle question. This will throw an error if both are passed in. That being said if you want to utalize question && relevant, you can get stream results by passing in relevance with options.question:true. This will handle multiple conversations. This is a Websocket. + * /qgpt/stream [GET] + */ + async qgptStream(requestParameters) { + const response = await this.qgptStreamRaw(requestParameters); + return await response.value(); + } /** * This is going to accept, relevant code snippets or uuids returned from the /qgpt/relevance endpoint, as well as a question query and we will return possible results to answer your question. NOTE: - The relevant seeds, must require either an id, that was used within the /qgpt/relevance endpoint or a seed with afragment/string. or else we will throw and error. This endpoint will take your query and your relevant snippets and use them to answer your question, returning multiple answers to your question all of which with scores. * /qgpt/question [POST] @@ -18738,7 +19000,7 @@ var WellKnownApi = class extends BaseAPI2 { }; // package.json -var version = "1.2.2"; +var version = "1.3.0"; // src/connection/notification_handler.ts var import_obsidian = require("obsidian"); @@ -19080,10 +19342,10 @@ Constants.askQGPTTitle = "Ask copilot about your selection"; var import_crypto = __toESM(require("crypto")); // src/database/pieces_database.ts -var import_obsidian13 = require("obsidian"); +var import_obsidian14 = require("obsidian"); // src/ui/views/DisplayController.ts -var import_obsidian12 = require("obsidian"); +var import_obsidian13 = require("obsidian"); // assets/classifications/batchfile-white.png var batchfile_white_default = ""; @@ -19378,10 +19640,6 @@ var LangSpecificEnum = { var searchLangSpecificEnum = { asp: "Asp", bat: "Batch", - sh: "Bash", - cc: "C++ Source", - hh: "C++ H-Header", - h: "C++ Header", c: "C", cs: "C#", cpp: "C++", @@ -19397,7 +19655,6 @@ var searchLangSpecificEnum = { groovy: "Groovy", hs: "Haskell", html: "HTML", - htm: "HTM", java: "Java", js: "JavaScript", json: "JSON", @@ -19411,23 +19668,21 @@ var searchLangSpecificEnum = { text: "PlainTextGrammar", ps1: "PowerShell", py: "Python", - pyc: "Python-C", rb: "Ruby", r: "R", rs: "Rust", scala: "Scala", + sh: "Shell", sol: "Solidity", sql: "SQL", swift: "Swift", sv: "SystemVerilog", tex: "TeX", - tml: "TOML", toml: "TOML", ts: "TypeScript", txt: "PlainTextGrammar", xml: "XML", - yaml: "YAML", - yml: "YAML" + yaml: "YAML" }; var SearchLangToClassificationEnum = { Batch: "bat" /* Bat */, @@ -19440,14 +19695,10 @@ var SearchLangToClassificationEnum = { "Objective-C": "m" /* M */, C: "c" /* C */, "C++": "cpp" /* Cpp */, - "C++ Source": "cc" /* Cc */, - "C++ Header": "h" /* H */, - "C++ H-Header": "hh" /* Hh */, "C#": "cs" /* Cs */, CSS: "css" /* Css */, Go: "go" /* Go */, HTML: "html" /* Html */, - HTM: "htm" /* Htm */, Java: "java" /* Java */, JavaScript: "js" /* Js */, TypeScript: "ts" /* Ts */, @@ -19457,10 +19708,9 @@ var SearchLangToClassificationEnum = { Perl: "pl" /* Pl */, PHP: "php" /* Php */, Python: "py" /* Py */, - "Python-C": "pyc" /* Pyc */, PowerShell: "ps1" /* Ps1 */, R: "r" /* R */, - Bash: "sh" /* Sh */, + Shell: "sh" /* Sh */, Swift: "swift" /* Swift */, Ruby: "rb" /* Rb */, TeX: "tex" /* Tex */, @@ -19468,7 +19718,7 @@ var SearchLangToClassificationEnum = { Rust: "rs" /* Rs */, JSON: "json" /* Json */, YAML: "yaml" /* Yaml */, - TOML: "tml" /* Tml */, + TOML: "toml" /* Toml */, XML: "xml" /* Xml */, Groovy: "groovy" /* Groovy */, Kotlin: "kt" /* Kt */, @@ -19535,8 +19785,10 @@ var displayPiecesView = async ({ await leaf.open(view); leaf.view.inlineTitleEl.innerHTML = inlineTitle; leaf.view.inlineTitleEl.contentEditable = "false"; + leaf.view.inlineTitleEl.style.userSelect = "text"; const editor = view.editor.cm; editor.contentDOM.contentEditable = "false"; + editor.contentDOM.style.userSelect = "text"; let inView = true; while (inView) { if (view.file) { @@ -20641,7 +20893,7 @@ var AnnotationHandler = class { // src/ui/modals/edit-asset-modal.ts var EditModal = class extends import_obsidian5.Modal { - constructor(app2, snippetObject, snippetEl) { + constructor(app2, snippetObject) { super(app2); this.snippetTitle = snippetObject.title; this.snippetId = snippetObject.id; @@ -20649,7 +20901,6 @@ var EditModal = class extends import_obsidian5.Modal { this.snippetLanguage = snippetObject.language; this.seperatedRaw = (snippetObject.raw || "").split("\n"); this.snippetAnnotations = snippetObject.annotations || []; - this.snippetEl = snippetEl; } onOpen() { var _a; @@ -21176,7 +21427,7 @@ function renderSnippet({ buttonDiv.createEl("div").addClass("vertBreak"); if (!newSnippet && !discovery) { new import_obsidian8.ButtonComponent(buttonDiv).setIcon("pencil").setTooltip("Edit snippet").onClick(async () => { - new EditModal(this.app, snippetObject, contentEl).open(); + new EditModal(this.app, snippetObject).open(); }).setClass("button"); buttonDiv.createEl("div").addClass("vertBreak"); new import_obsidian8.ButtonComponent(buttonDiv).setIcon("sticky-note").setTooltip("Edit annotations").onClick(async () => { @@ -22427,12 +22678,485 @@ var ProgressBar = class { } }; +// src/ui/modals/search-filters-modal.ts +var import_obsidian12 = require("obsidian"); +var FilterTypeEnum = /* @__PURE__ */ ((FilterTypeEnum2) => { + FilterTypeEnum2["Language"] = "Language"; + FilterTypeEnum2["Tags"] = "Tags"; + FilterTypeEnum2["Phrase"] = "Phrase"; + return FilterTypeEnum2; +})(FilterTypeEnum || {}); +var SearchFiltersModal = class extends import_obsidian12.Modal { + constructor(app2) { + super(app2); + this.filtersRan = false; + this.addedFilters = []; + this.filters = { Tags: [], casing: false }; + this.titleEl.setText("Filter Snippets"); + const container = this.contentEl.createDiv(); + container.classList.add("flex", "flex-col", "w-full", "h-full"); + const description = container.createDiv(); + description.classList.add( + "text-sm", + "flex", + "flex-row", + "w-full", + "mt-[-8px]", + "mb-1", + "text-[var(--text-faint)]" + ); + description.setText( + "Use filters to narrow your search scope & refine results" + ); + const filtersRow = container.createDiv(); + filtersRow.classList.add("flex", "flex-row", "w-full", "h-full"); + const filtersCol = filtersRow.createDiv(); + filtersCol.classList.add("flex", "flex-col", "w-full", "h-full"); + const actionRow = container.createDiv(); + actionRow.classList.add("flex", "flex-row", "w-full", "mt-2"); + const addCol = actionRow.createDiv(); + addCol.classList.add("flex", "flex-col", "min-h-[32px]"); + const addButton = new import_obsidian12.ButtonComponent(addCol); + addButton.setButtonText("Add Filter").onClick(() => { + this.addFilter(addCol, filtersCol, addButton); + addButton.buttonEl.classList.add("hidden"); + }).buttonEl.classList.add("w-fit", "mr-2"); + this.addButton = addButton.buttonEl; + const caseCol = actionRow.createDiv(); + caseCol.classList.add("flex", "flex-col", "hidden", "w-full"); + const caseRow = caseCol.createDiv(); + caseRow.classList.add( + "flex", + "flex-row", + "w-full", + "items-center", + "h-full" + ); + const caseCheckBox = caseRow.createEl("input", { type: "checkbox" }); + caseCheckBox.onchange = () => { + this.filters.casing = caseCheckBox.checked; + }; + const caseLabel = caseRow.createDiv(); + caseLabel.classList.add("w-full"); + caseLabel.setText("Case Sensitive"); + this.caseDiv = caseCol; + const actionCol = actionRow.createDiv(); + actionCol.classList.add("flex", "flex-col", "w-full", "hidden"); + this.actionCol = actionCol; + const actionBtnRow = actionCol.createDiv(); + actionBtnRow.classList.add("flex", "flex-row", "justify-end", "w-full"); + const clearBtn = new import_obsidian12.ButtonComponent(actionBtnRow); + clearBtn.onClick(() => { + var _a; + (_a = document.getElementById("pieces-filters-options")) == null ? void 0 : _a.remove(); + filtersCol.empty(); + this.addedFilters = []; + this.filters = { Tags: [], casing: false }; + actionCol.classList.add("hidden"); + this.addButton.classList.remove("hidden"); + this.caseDiv.classList.add("hidden"); + this.handleClear(); + }); + clearBtn.setButtonText("Clear Filters"); + clearBtn.buttonEl.classList.add("mr-2"); + const runBtn = new import_obsidian12.ButtonComponent(actionBtnRow); + runBtn.onClick(() => { + this.runFilters(); + }); + runBtn.setButtonText("Run"); + } + handleClear() { + if (this.filtersRan) { + this.filtersRan = false; + DisplayController.triggerUIRedraw({ searching: false, fetch: false }); + DisplayController.filterModalBtn.buttonEl.classList.remove( + "text-[var(--text-accent)]" + ); + } + } + /* + Creates a delete button + - @param parent is the element that should be removed when the delete button is clicked + - @param container is the element the delete button should be appended to + */ + buildDeleteBtn(parent, container, filter) { + const delDiv = container.createDiv(); + delDiv.innerHTML = (0, import_obsidian12.getIcon)("trash-2").outerHTML; + delDiv.classList.add( + "hover:text-red-600", + "cursor-pointer", + "ml-2", + "mr-2" + ); + delDiv.onclick = () => { + var _a; + parent.remove(); + (_a = document.getElementById("pieces-filters-options")) == null ? void 0 : _a.remove(); + this.addedFilters.remove(filter); + this.addButton.classList.remove("hidden"); + if (this.addedFilters.length === 0) { + this.actionCol.classList.add("hidden"); + this.handleClear(); + } + delete this.filters[filter]; + if (!this.addedFilters.contains("Tags") && !this.addedFilters.contains("Phrase")) { + this.caseDiv.classList.add("hidden"); + this.filters.casing = false; + } + }; + return delDiv; + } + /* + Runs the filter request, and renders the results. + */ + async runFilters() { + var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j; + const config2 = ConnectorSingleton.getInstance(); + const params = { + transferables: false, + pseudo: false, + assetsSearchWithFiltersInput: { + filters: { + iterable: [] + }, + casing: this.filters.casing + } + }; + if ((_a = this.filters.Language) == null ? void 0 : _a.length) { + (_c = (_b = params.assetsSearchWithFiltersInput) == null ? void 0 : _b.filters) == null ? void 0 : _c.iterable.push({ + classification: this.filters.Language + }); + } + if (this.filters.Tags.filter((el) => el.length).length) { + (_e = (_d = params.assetsSearchWithFiltersInput) == null ? void 0 : _d.filters) == null ? void 0 : _e.iterable.push({ + tags: this.filters.Tags + }); + } + if ((_f = this.filters.Phrase) == null ? void 0 : _f.string.length) { + const operations = { + iterable: [], + type: "OR" /* Or */ + }; + const value = this.filters.Phrase.string; + if (this.filters.Phrase.annotations) { + operations.iterable.push({ + phrase: { value, annotation: true } + }); + } + if (this.filters.Phrase.content) { + operations.iterable.push({ + phrase: { value, content: true } + }); + } + if (this.filters.Phrase.titles) { + operations.iterable.push({ + phrase: { value, title: true } + }); + } + if (operations.iterable.length) { + (_h = (_g = params.assetsSearchWithFiltersInput) == null ? void 0 : _g.filters) == null ? void 0 : _h.iterable.push({ + operations + }); + } + } + if (!((_j = (_i = params.assetsSearchWithFiltersInput) == null ? void 0 : _i.filters) == null ? void 0 : _j.iterable.length)) { + Notifications.getInstance().error({ + message: "Filters were empty, skipping." + }); + return; + } + const assets = await config2.assetsApi.assetsSearchWithFilters(params).catch(() => { + Notifications.getInstance().error({ + message: "Something went wrong with filtering your snippets. Please make sure that Pieces OS is installed, updated, and running. If the issue persists please contact support@pieces.app" + }); + }); + if (!assets) + return; + if (!assets.results.iterable.length) { + Notifications.getInstance().error({ + message: "No results found! Try again with a different set of filters." + }); + return; + } else { + Notifications.getInstance().information({ + message: `${assets.results.iterable.length} results found!` + }); + } + this.filtersRan = true; + const cache2 = PiecesCacheSingleton.getInstance(); + const snippets = cache2.assets.filter( + (el) => assets.results.iterable.some((asset) => asset.identifier === el.id) + ); + DisplayController.defaultView = "newest" /* RECENT */; + DisplayController.createSnippetListView({ + containerVar: DisplayController.defaultContainer, + snippets + }); + DisplayController.filterModalBtn.buttonEl.classList.add( + "text-[var(--text-accent)]" + ); + this.close(); + } + /* + Builder for classification filter element + */ + buildClassificationEl(container) { + const clsRow = container.createDiv(); + clsRow.classList.add("flex", "flex-row", "my-2"); + const clsCol = clsRow.createDiv(); + clsCol.classList.add("flex", "flex-col"); + const labelRow = clsCol.createDiv(); + labelRow.classList.add( + "flex", + "flex-row", + "text-sm", + "text-[var(--text-faint)]" + ); + labelRow.setText("LANGUAGE"); + const filterRow = clsCol.createDiv(); + filterRow.classList.add("flex", "flex-row", "items-center"); + const classificationDropdown = new import_obsidian12.DropdownComponent(filterRow); + classificationDropdown.selectEl.classList.add("w-fit", "text-center"); + classificationDropdown.addOptions(searchLangSpecificEnum); + classificationDropdown.onChange((value) => { + this.filters["Language" /* Language */] = langExtToClassificationSpecificEnum(value); + }); + this.filters["Language" /* Language */] = langExtToClassificationSpecificEnum( + classificationDropdown.getValue() + ); + this.buildDeleteBtn(clsRow, filterRow, "Language" /* Language */); + } + /* + Builder for phrase filter element + */ + buildPhraseEl(container) { + this.filters["Phrase" /* Phrase */] = { + string: "", + annotations: true, + titles: true, + content: true + }; + const phraseRow = container.createDiv(); + phraseRow.classList.add("flex", "flex-row", "my-2", "w-full"); + const phraseCol = phraseRow.createDiv(); + phraseCol.classList.add("flex", "flex-col", "w-full"); + const phraseLabel = phraseCol.createDiv(); + phraseLabel.classList.add( + "flex-row", + "flex", + "text-sm", + "text-[var(--text-faint)]" + ); + phraseLabel.setText("PHRASE"); + const inputRow = phraseCol.createDiv(); + inputRow.classList.add( + "flex", + "flex-row", + "my-1", + "w-full", + "items-center" + ); + const inputEl = new import_obsidian12.TextComponent(inputRow); + inputEl.setPlaceholder("Filter for an exact text match"); + inputEl.inputEl.classList.add("w-1/2"); + inputEl.onChange((value) => { + this.filters["Phrase" /* Phrase */].string = value; + }); + const optionRow = phraseCol.createDiv(); + optionRow.classList.add( + "flex", + "flex-row", + "w-full", + "items-center", + "my-1" + ); + const annotationCheckBox = optionRow.createEl("input", { + type: "checkbox" + }); + annotationCheckBox.checked = true; + annotationCheckBox.onchange = () => { + this.filters["Phrase" /* Phrase */].annotations = annotationCheckBox.checked; + }; + const annotationLabel = optionRow.createDiv(); + annotationLabel.setText("Match Annotations"); + annotationLabel.classList.add("mx-1"); + const seperatorEl = optionRow.createDiv(); + seperatorEl.classList.add( + "ml-2", + "mr-3", + "text-xs", + "text-[var(--text-faint)]" + ); + seperatorEl.setText("OR"); + const titleCheckbox = optionRow.createEl("input", { type: "checkbox" }); + titleCheckbox.checked = true; + titleCheckbox.onchange = () => { + this.filters["Phrase" /* Phrase */].titles = titleCheckbox.checked; + }; + const titleLabel = optionRow.createDiv(); + titleLabel.setText("Match Titles"); + titleLabel.classList.add("mx-1"); + optionRow.appendChild(seperatorEl.cloneNode(true)); + const contentCheckbox = optionRow.createEl("input", { type: "checkbox" }); + contentCheckbox.checked = true; + contentCheckbox.onchange = () => { + this.filters.Phrase.content = contentCheckbox.checked; + }; + const contentLabel = optionRow.createDiv(); + contentLabel.setText("Match Content"); + contentLabel.classList.add("mx-1"); + this.buildDeleteBtn(phraseRow, inputRow, "Phrase" /* Phrase */); + } + buildTagEl(container) { + const tagRow = container.createDiv(); + tagRow.classList.add("flex", "flex-row", "my-2"); + const tagCol = tagRow.createDiv(); + tagCol.classList.add("flex", "flex-col"); + const tagLabel = tagCol.createDiv(); + tagLabel.classList.add( + "flex", + "flex-row", + "my-1", + "text-sm", + "text-[var(--text-faint)]" + ); + tagLabel.setText("TAGS"); + const filtersRow = tagCol.createDiv(); + filtersRow.classList.add( + "flex", + "flex-row", + "my-1", + "items-center", + "flex-wrap" + ); + let tagInputCount = 0; + const buildTagInput = () => { + const tagIndx = tagInputCount.valueOf(); + tagInputCount++; + this.filters["Tags" /* Tags */].push(""); + filtersRow.empty(); + for (const tag of this.filters["Tags" /* Tags */]) { + const tagFilterCol = filtersRow.createDiv(); + tagFilterCol.classList.add("flex", "flex-col"); + const tagFilterRow = tagFilterCol.createDiv(); + tagFilterRow.classList.add("flex", "flex-row", "items-center", "my-1"); + const tagFilterEl = new import_obsidian12.TextComponent(tagFilterRow); + tagFilterEl.setValue(tag); + tagFilterEl.onChange((value) => { + this.filters["Tags" /* Tags */][tagIndx] = value; + }); + tagFilterEl.setPlaceholder("Add tag..."); + tagFilterEl.inputEl.classList.add("mr-1"); + const deleteBtn = this.buildDeleteBtn( + tagFilterCol, + tagFilterRow, + "Tags" /* Tags */ + ); + deleteBtn.onclick = () => { + var _a, _b; + (_a = document.getElementById("pieces-filters-options")) == null ? void 0 : _a.remove(); + tagInputCount--; + (_b = this.filters["Tags" /* Tags */]) == null ? void 0 : _b.remove(tagFilterEl.getValue()); + tagFilterCol.remove(); + if (tagInputCount <= 0) { + tagRow.remove(); + this.addButton.classList.remove("hidden"); + this.addedFilters.remove("Tags" /* Tags */); + if (this.addedFilters.length === 0) { + this.actionCol.classList.add("hidden"); + this.handleClear(); + } + if (!this.addedFilters.contains("Tags") && !this.addedFilters.contains("Phrase")) { + this.caseDiv.classList.add("hidden"); + this.filters.casing = false; + } + } + }; + } + const plusEl = filtersRow.createDiv(); + plusEl.classList.add( + "mx-1", + "cursor-pointer", + "hover:text-[var(--text-accent-hover)]" + ); + plusEl.innerHTML = (0, import_obsidian12.getIcon)("plus").outerHTML; + plusEl.onclick = () => { + buildTagInput(); + }; + }; + buildTagInput(); + } + buildFilterEl(type, container) { + if (type === "Language" /* Language */) { + return this.buildClassificationEl(container); + } else if (type === "Phrase" /* Phrase */) { + return this.buildPhraseEl(container); + } else if (type === "Tags" /* Tags */) { + return this.buildTagEl(container); + } + throw new Error("Invalid filter type"); + } + /* + Shows the available filter options to the user, + and when an option is clicked it will build a filter element + */ + addFilter(container, filterCol, addButton) { + const options2 = Object.keys(FilterTypeEnum).filter( + (el) => !this.addedFilters.includes(el) + ); + const optionDiv = document.createElement("div"); + optionDiv.id = "pieces-filters-options"; + optionDiv.classList.add( + "flex", + "flex-row", + "items-center", + "filter-grow-animation", + "h-full", + "mr-1" + ); + for (let i = 0; i < options2.length; i++) { + const option = options2[i]; + if (i !== 0) { + const split = optionDiv.createDiv(); + split.classList.add("mx-1", "text-[var(--text-faint)]"); + split.setText("|"); + } + const curOption = optionDiv.createDiv(); + curOption.classList.add( + "underline", + "cursor-pointer", + "mx-1", + "hover:text-[var(--text-accent-hover)]", + "text-[var(--text-faint)]" + ); + curOption.setText(option); + curOption.onclick = () => { + this.addedFilters.push(option); + this.buildFilterEl( + FilterTypeEnum[option], + filterCol + ); + optionDiv.remove(); + this.actionCol.classList.remove("hidden"); + if (this.addedFilters.length !== Object.keys(FilterTypeEnum).length) { + addButton.buttonEl.classList.remove("hidden"); + } + if (option === "Tags" || option === "Phrase") { + this.caseDiv.classList.remove("hidden"); + } + }; + } + container.appendChild(optionDiv); + } +}; + // src/ui/views/DisplayController.ts var _DisplayController = class { constructor() { } }; var DisplayController = _DisplayController; +DisplayController.searchFiltersModal = new SearchFiltersModal(app); DisplayController.defaultView = "newest" /* RECENT */; DisplayController.discoveryCheckboxArray = []; DisplayController.snippetsFetched = false; @@ -22507,7 +23231,7 @@ DisplayController.createSnippetListView = async ({ renderSearchBox({ containerVar: searchDiv }); const titleDiv = searchDiv.createDiv(); titleDiv.addClass("title_div"); - new import_obsidian12.DropdownComponent(titleDiv).addOption("newest" /* RECENT */, "\u{1F553} RECENT").addOption("language" /* LANGUAGE */, "\u{1F310} LANGUAGE").addOption("discovery" /* DISCOVERY */, "\u{1F50D} DISCOVER").onChange(async (value) => { + new import_obsidian13.DropdownComponent(titleDiv).addOption("newest" /* RECENT */, "\u{1F553} RECENT").addOption("language" /* LANGUAGE */, "\u{1F310} LANGUAGE").addOption("discovery" /* DISCOVERY */, "\u{1F50D} DISCOVER").onChange(async (value) => { _DisplayController.defaultView = value; _DisplayController.createSnippetListView({ containerVar, @@ -22515,6 +23239,21 @@ DisplayController.createSnippetListView = async ({ viewType: value }); }).setValue(viewType).selectEl.addClass("sort-dropdown"); + if (_DisplayController.defaultView !== "discovery" /* DISCOVERY */) { + const disableFilters = versionCheck({ minVersion: "6.1.0" }); + _DisplayController.filterModalBtn = new import_obsidian13.ButtonComponent(titleDiv); + _DisplayController.filterModalBtn.setIcon("filter").onClick(() => { + disableFilters.then((val) => { + if (val) { + _DisplayController.searchFiltersModal.open(); + } else { + Notifications.getInstance().error({ + message: "Please update to Pieces OS 6.1.0 or higher to use the snippet filtering feature." + }); + } + }).catch(_DisplayController.searchFiltersModal.open); + }).setTooltip("Filter your snippets").buttonEl.addClass("cursor-pointer"); + } if (_DisplayController.defaultView === "discovery" /* DISCOVERY */) { const saveAllDiv = titleDiv.createDiv(); saveAllDiv.addClasses(["discovery-div"]); @@ -22540,7 +23279,7 @@ DisplayController.createSnippetListView = async ({ selectAllLabel.innerText = "Select all"; selectAllLabel.addClasses(["discovery-title"]); saveAllDiv.createEl("div").addClass("discovery-break"); - const saveallButton = new import_obsidian12.ButtonComponent(saveAllDiv).setButtonText("Save all selected snippets").onClick(async () => { + const saveallButton = new import_obsidian13.ButtonComponent(saveAllDiv).setButtonText("Save all selected snippets").onClick(async () => { _DisplayController.defaultView = "discovery" /* DISCOVERY */; const loading = saveAllDiv.createEl("div"); loading.addClass("bouncing-loader"); @@ -22751,7 +23490,7 @@ var PiecesDatabase = class { } return vault.create(dbPath, '{"assets":[]}'); } - if (dataFile instanceof import_obsidian13.TFolder) { + if (dataFile instanceof import_obsidian14.TFolder) { await vault.delete(dataFile); return vault.create(dbPath, '{"assets":[]}'); } @@ -23126,7 +23865,7 @@ var fetchFormatTransferable = async ({ }; // src/settings/index.ts -var import_obsidian14 = require("obsidian"); +var import_obsidian15 = require("obsidian"); // src/actions/login.ts var login = async () => { @@ -23178,7 +23917,7 @@ var youtube_default = " var twitter_default = ""; // src/settings/index.ts -var PiecesSettingTab = class extends import_obsidian14.PluginSettingTab { +var PiecesSettingTab = class extends import_obsidian15.PluginSettingTab { constructor(app2, plugin) { super(app2, plugin); this.cloud = CloudService.getInstance(); @@ -23189,36 +23928,36 @@ var PiecesSettingTab = class extends import_obsidian14.PluginSettingTab { const config2 = ConnectorSingleton.getInstance(); containerEl.empty(); containerEl.createEl("h1", { text: "Pieces Settings" }); - new import_obsidian14.Setting(containerEl).setName(Constants.SHOW_TUTORIAL).setDesc(Constants.TUTORIAL_DESCRIPTION).addButton( + new import_obsidian15.Setting(containerEl).setName(Constants.SHOW_TUTORIAL).setDesc(Constants.TUTORIAL_DESCRIPTION).addButton( (comp) => comp.setButtonText("Show").onClick(() => { this.plugin.showOnboarding(); }).setClass("button") ); - new import_obsidian14.Setting(containerEl).setName(Constants.TOGGLE_AUTOOPEN).setDesc(Constants.TOGGLE_AUTOOPEN_DESC).addToggle( + new import_obsidian15.Setting(containerEl).setName(Constants.TOGGLE_AUTOOPEN).setDesc(Constants.TOGGLE_AUTOOPEN_DESC).addToggle( (comp) => comp.setValue(this.plugin.settings.autoOpen).onChange((value) => { this.plugin.settings.autoOpen = value; this.plugin.saveSettings(); }) ); - new import_obsidian14.Setting(containerEl).setName(Constants.ENRICH_PERSISTENCE).setDesc(Constants.ENRICH_PERSISTENCE_DESC).addToggle((comp) => { + new import_obsidian15.Setting(containerEl).setName(Constants.ENRICH_PERSISTENCE).setDesc(Constants.ENRICH_PERSISTENCE_DESC).addToggle((comp) => { comp.setValue(this.plugin.settings.enrich_confirmation).onChange((value) => { this.plugin.settings.enrich_confirmation = value; this.plugin.saveSettings(); }); }); - new import_obsidian14.Setting(containerEl).setName(Constants.TOGGLE_AUTODISCOVER).setDesc(Constants.TOGGLE_AUTODISCOVER_DESC).addToggle( + new import_obsidian15.Setting(containerEl).setName(Constants.TOGGLE_AUTODISCOVER).setDesc(Constants.TOGGLE_AUTODISCOVER_DESC).addToggle( (comp) => comp.setValue(this.plugin.settings.autoDiscover).onChange(async (value) => { this.plugin.settings.autoDiscover = value; this.plugin.saveSettings(); }) ); - new import_obsidian14.Setting(containerEl).setName(Constants.TOGGLE_USE_NOTE_TITLE).setDesc(Constants.TOGGLE_USE_NOTE_TITLE_DESC).addToggle((comp) => { + new import_obsidian15.Setting(containerEl).setName(Constants.TOGGLE_USE_NOTE_TITLE).setDesc(Constants.TOGGLE_USE_NOTE_TITLE_DESC).addToggle((comp) => { comp.setValue(this.plugin.settings.use_note_title).onChange(async (value) => { this.plugin.settings.use_note_title = value; this.plugin.saveSettings(); }); }); - new import_obsidian14.Setting(containerEl).setName(Constants.TOGGLE_AUTODISCOVER_MAX).setDesc(Constants.TOGGLE_AUTODISCOVER_DESC_MAX).addSlider( + new import_obsidian15.Setting(containerEl).setName(Constants.TOGGLE_AUTODISCOVER_MAX).setDesc(Constants.TOGGLE_AUTODISCOVER_DESC_MAX).addSlider( (comp) => comp.setLimits(1, 200, 1).setDynamicTooltip().setValue(this.plugin.settings.autoDiscoverMaximum).onChange(async (value) => { this.plugin.settings.autoDiscoverMaximum = value; if (DisplayController.discoveryProgressBar) @@ -23226,7 +23965,7 @@ var PiecesSettingTab = class extends import_obsidian14.PluginSettingTab { await this.plugin.saveSettings(); }) ); - new import_obsidian14.Setting(containerEl).setName(Constants.CLOUD_SELECT).setDesc(Constants.CLOUD_SELECT_DESC).addDropdown( + new import_obsidian15.Setting(containerEl).setName(Constants.CLOUD_SELECT).setDesc(Constants.CLOUD_SELECT_DESC).addDropdown( (comp) => comp.addOptions({ blended: "Blended", local: "Local", @@ -23239,10 +23978,10 @@ var PiecesSettingTab = class extends import_obsidian14.PluginSettingTab { } ) ); - new import_obsidian14.Setting(containerEl).setName(Constants.PORT_PROMPT).addText((comp) => comp.setValue(Constants.PORT_VALUE).setDisabled(true)).setDesc(Constants.PORT_DESCRIPTION); + new import_obsidian15.Setting(containerEl).setName(Constants.PORT_PROMPT).addText((comp) => comp.setValue(Constants.PORT_VALUE).setDisabled(true)).setDesc(Constants.PORT_DESCRIPTION); let user = (await config2.userApi.userSnapshot()).user; if (user) { - new import_obsidian14.Setting(containerEl).setName(Constants.LOGOUT_TITLE).setDesc(Constants.LOGOUT_DESC).addButton( + new import_obsidian15.Setting(containerEl).setName(Constants.LOGOUT_TITLE).setDesc(Constants.LOGOUT_DESC).addButton( (comp) => comp.setButtonText("Logout").onClick(async () => { const success = await logout(); if (success) { @@ -23251,7 +23990,7 @@ var PiecesSettingTab = class extends import_obsidian14.PluginSettingTab { }).setClass("button") ); } else { - new import_obsidian14.Setting(containerEl).setName(Constants.LOGIN_TITLE).setDesc(Constants.LOGIN_DESC).addButton( + new import_obsidian15.Setting(containerEl).setName(Constants.LOGIN_TITLE).setDesc(Constants.LOGIN_DESC).addButton( (comp) => comp.setButtonText("Login").onClick(async () => { const success = await login(); user = (await config2.userApi.userSnapshot()).user; @@ -23399,10 +24138,10 @@ var DEFAULT_SETTINGS = { }; // src/ui/views/pieces-snippet-list-view.ts -var import_obsidian20 = require("obsidian"); +var import_obsidian21 = require("obsidian"); // src/ui/views/GPTController.ts -var import_obsidian19 = require("obsidian"); +var import_obsidian20 = require("obsidian"); // src/actions/qgpt.ts var QGPT = class { @@ -25792,7 +26531,7 @@ var lexer = Lexer.lex; // src/ui/plugins/SaveToPiecesWidget.ts var import_view = require("@codemirror/view"); -var import_obsidian16 = require("obsidian"); +var import_obsidian17 = require("obsidian"); // src/actions/auto_link.ts var AutoLinker = class { @@ -25975,7 +26714,7 @@ var DebounceNCS = class { }; // src/ui/modals/enriched-modal.ts -var import_obsidian15 = require("obsidian"); +var import_obsidian16 = require("obsidian"); // assets/Robot_Enrich.png var Robot_Enrich_default = ""; @@ -25984,7 +26723,7 @@ var Robot_Enrich_default = " var Robot_Enrich_DM_default = ""; // src/ui/modals/enriched-modal.ts -var EnrichedModal = class extends import_obsidian15.Modal { +var EnrichedModal = class extends import_obsidian16.Modal { constructor(app2, enrichButton, code) { super(app2); this.code = code; @@ -26004,14 +26743,14 @@ var EnrichedModal = class extends import_obsidian15.Modal { enrichConfirmImg.setAttr("width", "auto"); const btnRow = this.contentEl.createDiv(); btnRow.addClass("enrich-btn-row"); - new import_obsidian15.ButtonComponent(btnRow).setButtonText("Yes").setIcon("check").onClick(() => { + new import_obsidian16.ButtonComponent(btnRow).setButtonText("Yes").setIcon("check").onClick(() => { const clickEvent = new Event("click"); const cache2 = PiecesCacheSingleton.getInstance(); cache2.setIsEnriched(this.code, false); this.enrichButton.buttonEl.dispatchEvent(clickEvent); this.close(); }).setClass("enrich-confirm-btn").setTooltip("Continue enrichment"); - new import_obsidian15.ButtonComponent(btnRow).setButtonText("No").onClick(() => { + new import_obsidian16.ButtonComponent(btnRow).setButtonText("No").onClick(() => { this.close(); }).setIcon("x").setClass("enrich-deny-btn").setTooltip("Cancel enrichment"); } @@ -26047,7 +26786,7 @@ var SaveToPiecesWidget = class extends import_view.WidgetType { } }; this.enrichButton = (container, holderDiv) => { - const enrichBtn = new import_obsidian16.ButtonComponent(container).onClick(async () => { + const enrichBtn = new import_obsidian17.ButtonComponent(container).onClick(async () => { var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k; const cache2 = PiecesCacheSingleton.getInstance(); if (cache2.getIsEnriched(this.codeBlock) && pluginSettings.enrich_confirmation) { @@ -26112,7 +26851,7 @@ var SaveToPiecesWidget = class extends import_view.WidgetType { }).setTooltip("Enrich code snippet").setClass("save-to-pieces-btn").setIcon("sparkles"); }; this.expandButton = (container, ID) => { - const expandButton = new import_obsidian16.ButtonComponent(container).onClick(async () => { + const expandButton = new import_obsidian17.ButtonComponent(container).onClick(async () => { if (!ID) { this.notifications.error({ message: Constants.EXPAND_ERROR @@ -26127,7 +26866,7 @@ var SaveToPiecesWidget = class extends import_view.WidgetType { return expandButton; }; this.shareButton = (container, holderDiv) => { - const shareButton = new import_obsidian16.ButtonComponent(container).onClick(async () => { + const shareButton = new import_obsidian17.ButtonComponent(container).onClick(async () => { const loading = holderDiv.createEl("div"); loading.addClass("share-code-bouncing-loader"); loading.createEl("div"); @@ -26172,18 +26911,36 @@ var SaveToPiecesWidget = class extends import_view.WidgetType { return shareButton; }; this.copyButton = (container) => { - const copyButton = new import_obsidian16.ButtonComponent(container).onClick(async () => { + const copyButton = new import_obsidian17.ButtonComponent(container).onClick(async () => { var _a; if (this.lang && this.codeBlock && this.codeBlock.substring(0, 3) !== "```\n") { this.codeBlock = "```" + this.lang + "\n" + this.codeBlock + "```"; } copyToClipboard((_a = this.codeBlock) != null ? _a : this.codeRaw); - new import_obsidian16.Notice("Snippet copied to clipboard!"); + new import_obsidian17.Notice("Snippet copied to clipboard!"); }).setTooltip("Copy code to clipboard").setClass("save-to-pieces-btn").setIcon("copy"); return copyButton; }; + this.editButton = (container, id) => { + const editBtn = new import_obsidian17.ButtonComponent(container).setIcon("pencil").setTooltip("Edit snippet").onClick(async () => { + new EditModal( + app, + PiecesCacheSingleton.getInstance().mappedAssets[id] + ).open(); + }).setClass("button"); + editBtn.buttonEl.classList.add("mr-1"); + }; + this.annotationsButton = (container, id) => { + const annotationButton = new import_obsidian17.ButtonComponent(container).setIcon("sticky-note").setTooltip("Edit annotations").onClick(async () => { + new AnnotationsModal( + app, + PiecesCacheSingleton.getInstance().mappedAssets[id] + ).open(); + }).setClass("button"); + annotationButton.buttonEl.classList.add("mr-1"); + }; this.saveButton = (container, holderDiv) => { - const saveButton = new import_obsidian16.ButtonComponent(container).onClick(async () => { + const saveButton = new import_obsidian17.ButtonComponent(container).onClick(async () => { const loading = holderDiv.createEl("div"); loading.addClass("share-code-bouncing-loader"); loading.createEl("div"); @@ -26237,7 +26994,7 @@ var SaveToPiecesWidget = class extends import_view.WidgetType { const { id } = this; const collapsedHolder = holderDiv.createDiv(); collapsedHolder.addClasses(["collapsed-pieces-holder", "collapsed"]); - const collapseControlButton = new import_obsidian16.ButtonComponent(holderDiv).onClick(async () => { + const collapseControlButton = new import_obsidian17.ButtonComponent(holderDiv).onClick(async () => { clearTimeout(this.tempCollapseTimer); if (collapsedHolder.classList.contains("collapsed")) { if (!this.piecesPreview) { @@ -26248,16 +27005,20 @@ var SaveToPiecesWidget = class extends import_view.WidgetType { if (id && this.cache.mappedAssets[id]) { this.expandButton(collapsedHolder, id); } else if (this.score > 0.97 && this.identifier && this.cache.mappedAssets[this.identifier]) { - this.expandButton(collapsedHolder, this.identifier); + this.expandButton(collapsedHolder, id != null ? id : this.identifier); + this.editButton(collapsedHolder, id != null ? id : this.identifier); + this.annotationsButton(collapsedHolder, id != null ? id : this.identifier); } else { this.saveButton(collapsedHolder, holderDiv); } } else { this.copyButton(collapsedHolder); + this.editButton(collapsedHolder, id != null ? id : this.identifier); + this.annotationsButton(collapsedHolder, id != null ? id : this.identifier); } this.shareButton(collapsedHolder, holderDiv); collapsedHolder.classList.remove("collapsed"); - const computedWidth = (5 + 42) * collapsedHolder.childElementCount; + const computedWidth = 47 * collapsedHolder.childElementCount; collapsedHolder.style.width = computedWidth + "px"; this.tempCollapseTimer = setTimeout(() => { this.tempCollapseTimer = void 0; @@ -26317,7 +27078,7 @@ var PlaceHolderWidget = class extends import_view.WidgetType { }; // src/actions/open_vault_note.ts -var import_obsidian17 = require("obsidian"); +var import_obsidian18 = require("obsidian"); var openVaultNote = (myPath) => { const cleanedPath = myPath.substring(myPath.lastIndexOf("/") + 1); const vaultFiles = app.vault.getFiles(); @@ -26332,7 +27093,7 @@ var openVaultNote = (myPath) => { console.error(`Target file error: ${targetFile}`); } } catch (e) { - new import_obsidian17.Notice(`Error opening ${myPath}, the file may not exist.`); + new import_obsidian18.Notice(`Error opening ${myPath}, the file may not exist.`); } }; @@ -26343,8 +27104,8 @@ var piecesCopilotW_default = " var piecesCopilotB_default = ""; // src/ui/modals/context-modal.ts -var import_obsidian18 = require("obsidian"); -var ContextModal = class extends import_obsidian18.Modal { +var import_obsidian19 = require("obsidian"); +var ContextModal = class extends import_obsidian19.Modal { constructor(app2) { super(app2); this.cache = PiecesCacheSingleton.getInstance(); @@ -26380,12 +27141,23 @@ var ContextModal = class extends import_obsidian18.Modal { }; currentNode.children.push(childNode); } - currentNode.children = currentNode.children.sort((a, b) => { - return b.children.length - a.children.length; - }); currentNode = childNode; } }); + const sortNodes = (node) => { + node.children = node.children.sort((a, b) => { + if (a.children.length && !b.children.length) { + return -1; + } else if (b.children.length && !a.children.length) { + return 1; + } + return a.name.localeCompare(b.name); + }); + for (const child of node.children) { + sortNodes(child); + } + }; + sortNodes(root); this.tree = root; return root; } @@ -26710,7 +27482,7 @@ GPTController.getProfile = async () => { img.src = profilePic; _GPTController.userSVG = img; } else { - _GPTController.userSVG = (0, import_obsidian19.getIcon)("userSVG"); + _GPTController.userSVG = (0, import_obsidian20.getIcon)("userSVG"); } }; GPTController.createGPTView = async ({ @@ -26729,7 +27501,7 @@ GPTController.createGPTView = async ({ const contextSpan = textDiv.createDiv(); contextSpan.addClasses(["gpt-context"]); contextSpan.title = "Select context"; - (0, import_obsidian19.setIcon)(contextSpan, "settings"); + (0, import_obsidian20.setIcon)(contextSpan, "settings"); contextSpan.onmouseup = async () => { _GPTController.contextModal.open(); }; @@ -26797,7 +27569,7 @@ GPTController.createGPTView = async ({ inputText.spellcheck = true; _GPTController.inputBox = inputText; const sendDiv = inputDiv.createEl("div"); - (0, import_obsidian19.setIcon)(sendDiv, "sendSVG"); + (0, import_obsidian20.setIcon)(sendDiv, "sendSVG"); sendDiv.addClasses(["gpt-img-small", "col-reverse", "justify-between"]); const sendSVG = sendDiv.firstChild; sendSVG.addClass("gpt-send-unactive"); @@ -26899,14 +27671,14 @@ GPTController.handleChat = async ({ _GPTController.userSVG.addClasses(["gpt-user-image"]); userDiv.appendChild(_GPTController.userSVG.cloneNode(true)); } else { - (0, import_obsidian19.setIcon)(userDiv, "userSVG"); + (0, import_obsidian20.setIcon)(userDiv, "userSVG"); } userDiv.addClasses(["gpt-img"]); textAreaDiv.prepend(queryDiv); const answerDiv = document.createElement("div"); answerDiv.addClasses(["gpt-row", "gpt-left-align"]); const aiDiv = answerDiv.createEl("div"); - (0, import_obsidian19.setIcon)(aiDiv, "aiSVG"); + (0, import_obsidian20.setIcon)(aiDiv, "aiSVG"); aiDiv.addClasses(["gpt-img"]); const answerEl = answerDiv.createEl("p"); answerEl.addClasses(["gpt-text-response", "gpt-response", "gpt-col"]); @@ -27013,14 +27785,14 @@ GPTController.buildCurrentConversation = (textAreaDiv) => { _GPTController.userSVG.addClasses(["gpt-user-image"]); userDiv.appendChild(_GPTController.userSVG.cloneNode(true)); } else { - (0, import_obsidian19.setIcon)(userDiv, "userSVG"); + (0, import_obsidian20.setIcon)(userDiv, "userSVG"); } userDiv.addClasses(["gpt-img"]); textAreaDiv.prepend(queryDiv); const answerDiv = document.createElement("div"); answerDiv.addClasses(["gpt-row", "gpt-left-align"]); const aiDiv = answerDiv.createEl("div"); - (0, import_obsidian19.setIcon)(aiDiv, "aiSVG"); + (0, import_obsidian20.setIcon)(aiDiv, "aiSVG"); aiDiv.addClasses(["gpt-img"]); const answerEl = answerDiv.createEl("p"); answerEl.addClasses(["gpt-text-response", "gpt-response", "gpt-col"]); @@ -27082,7 +27854,7 @@ GPTController.renderHints = ({ hintButtonText.textContent = hints.answers.iterable[i].text; const hintIcon = hintButton.createEl("div"); hintIcon.addClasses(["gpt-icon", "gpt-icon-drift"]); - (0, import_obsidian19.setIcon)(hintIcon, "sendSVG"); + (0, import_obsidian20.setIcon)(hintIcon, "sendSVG"); } }; /** @@ -27160,11 +27932,11 @@ GPTController.createNotePill = (note, noteListRow) => { noteButtonText.textContent = noteName != null ? noteName : ""; const noteButtonIcon = noteButton.createEl("div"); noteButtonIcon.addClass("gpt-icon", "gpt-icon-note"); - (0, import_obsidian19.setIcon)(noteButtonIcon, "openNote"); + (0, import_obsidian20.setIcon)(noteButtonIcon, "openNote"); }; // src/ui/views/pieces-snippet-list-view.ts -var PiecesSnippetListView = class extends import_obsidian20.ItemView { +var PiecesSnippetListView = class extends import_obsidian21.ItemView { // Current Tab that is selected constructor(leaf) { super(leaf); @@ -27912,8 +28684,8 @@ var findSimilarity = async (codeBlock) => { }; // src/ui/modals/ask-qgpt-modal.ts -var import_obsidian21 = require("obsidian"); -var AskQGPTModal = class extends import_obsidian21.Modal { +var import_obsidian22 = require("obsidian"); +var AskQGPTModal = class extends import_obsidian22.Modal { constructor(app2, selection) { super(app2); this.text = selection; @@ -27946,7 +28718,7 @@ var AskQGPTModal = class extends import_obsidian21.Modal { sendCol.classList.add("ask-col"); inputCol.classList.add("ask-col", "ask-col-input"); const sendDiv = sendCol.createEl("div"); - (0, import_obsidian21.setIcon)(sendDiv, "sendSVG"); + (0, import_obsidian22.setIcon)(sendDiv, "sendSVG"); sendDiv.addClasses(["gpt-img", "ask-send-svg"]); const sendSVG = sendDiv.firstChild; sendSVG.addClass("gpt-send-unactive"); @@ -27984,7 +28756,7 @@ var AskQGPTModal = class extends import_obsidian21.Modal { await PiecesPlugin.activateView(); const query = this.inputText.innerText; if (!query) { - new import_obsidian21.Notice("Please enter a question for the Copilot!"); + new import_obsidian22.Notice("Please enter a question for the Copilot!"); return; } const gptTab = document.getElementById("gpt-tab"); @@ -28010,7 +28782,7 @@ ${this.text.trim()}` var pluginSettings; var theme = "dark"; var Prism; -var _PiecesPlugin = class extends import_obsidian22.Plugin { +var _PiecesPlugin = class extends import_obsidian23.Plugin { constructor() { super(...arguments); this.notifications = Notifications.getInstance(); @@ -28025,7 +28797,7 @@ var _PiecesPlugin = class extends import_obsidian22.Plugin { }) => { var _a, _b; const markdownView = this.app.workspace.activeEditor; - if (markdownView instanceof import_obsidian22.MarkdownView) { + if (markdownView instanceof import_obsidian23.MarkdownView) { const editor = markdownView.editor; const selection = editor.getSelection(); if (selection.length < 5) { @@ -28080,7 +28852,7 @@ var _PiecesPlugin = class extends import_obsidian22.Plugin { this.notifications.error({ message: Constants.UPDATE_OS }); } }); - Prism = await (0, import_obsidian22.loadPrism)(); + Prism = await (0, import_obsidian23.loadPrism)(); theme = document.body.classList.contains("theme-dark") ? "dark" : "light"; document.body.addEventListener("change", () => { this.themeChange(); @@ -28215,7 +28987,7 @@ var _PiecesPlugin = class extends import_obsidian22.Plugin { }; this.askQGPT = () => { const markdownView = this.app.workspace.activeEditor; - if (markdownView instanceof import_obsidian22.MarkdownView) { + if (markdownView instanceof import_obsidian23.MarkdownView) { const editor = markdownView.editor; const selection = editor.getSelection(); if (selection.length < 5) { @@ -28355,16 +29127,16 @@ var _PiecesPlugin = class extends import_obsidian22.Plugin { theme = temptheme; }; this.addIcons = () => { - (0, import_obsidian22.addIcon)("pieces_logo", Constants.PIECES_LOGO); - (0, import_obsidian22.addIcon)("codeSVG", Constants.CODE_ICON); - (0, import_obsidian22.addIcon)("aiSVG", Constants.AI_ICON); - (0, import_obsidian22.addIcon)("save-all", Constants.SAVE_ALL_ICON); - (0, import_obsidian22.addIcon)("sparkles", Constants.ENRICH_ICON); - (0, import_obsidian22.addIcon)("openNote", Constants.OPEN_ICON); - (0, import_obsidian22.addIcon)("aiSVG", Constants.AI_ICON); - (0, import_obsidian22.addIcon)("userSVG", Constants.USER_ICON); - (0, import_obsidian22.addIcon)("sendSVG", Constants.SEND_ICON); - (0, import_obsidian22.addIcon)("sendSVG2", Constants.SEND_ICON); + (0, import_obsidian23.addIcon)("pieces_logo", Constants.PIECES_LOGO); + (0, import_obsidian23.addIcon)("codeSVG", Constants.CODE_ICON); + (0, import_obsidian23.addIcon)("aiSVG", Constants.AI_ICON); + (0, import_obsidian23.addIcon)("save-all", Constants.SAVE_ALL_ICON); + (0, import_obsidian23.addIcon)("sparkles", Constants.ENRICH_ICON); + (0, import_obsidian23.addIcon)("openNote", Constants.OPEN_ICON); + (0, import_obsidian23.addIcon)("aiSVG", Constants.AI_ICON); + (0, import_obsidian23.addIcon)("userSVG", Constants.USER_ICON); + (0, import_obsidian23.addIcon)("sendSVG", Constants.SEND_ICON); + (0, import_obsidian23.addIcon)("sendSVG2", Constants.SEND_ICON); }; } }; diff --git a/manifest.json b/manifest.json index e55b277..6f468d8 100644 --- a/manifest.json +++ b/manifest.json @@ -1,7 +1,7 @@ { "id": "pieces-for-developers", "name": "Pieces for Developers", - "version": "1.2.2", + "version": "1.3.0", "minAppVersion": "0.15.0", "description": "Streamline your coding workflow in Obsidian with the Pieces For Developers plugin, offering powerful features for capturing, managing, translating, and enhancing code snippets. (Closed Source) ", "author": "Pieces For Developers", diff --git a/styles.css b/styles.css index d2fb0cb..8fded77 100644 --- a/styles.css +++ b/styles.css @@ -1 +1 @@ -*,::backdrop,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }.container{width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}.collapse{visibility:collapse}.static{position:static}.absolute{position:absolute}.block{display:block}.flex{display:flex}.table{display:table}.hidden{display:none}.justify-between{justify-content:space-between}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.search-background{position:sticky;top:-21px;left:0;z-index:998;margin-top:-145px;margin-bottom:-14px;height:131px;flex-grow:1;background-color:var(--background-secondary)}.code-view{z-index:-1;height:auto;border-bottom-width:var(--background-modifier-border);border-bottom-color:solid}.code-view:last-child{border-bottom-color:none}.code-title-div{position:relative;margin-top:0;margin-bottom:0;display:flex;height:50px;flex-wrap:wrap;vertical-align:middle;justify-content:left}.code-title-div h1{position:absolute;left:38px;top:13.2px;margin-top:.125rem;height:30px;font-size:15px}.code-title-div img{position:absolute;left:7px;top:17.3px;margin-top:-3px;margin-right:.625rem;height:22px;width:22px}.code-title-div span{position:absolute;right:-1rem;margin-right:1.75rem;margin-top:.875rem;height:30px;font-size:17px}.code-button-input{z-index:997;order:-1;margin:0!important;display:block;height:49px!important;flex-grow:1;cursor:pointer;opacity:0}.code-title-div:hover{background:var(--background-primary)!important}.save-to-pieces-btn{margin-right:5px;margin-bottom:5px;height:29px;width:42px;cursor:pointer;align-items:left;background:none}.save-to-pieces-holder{margin-bottom:-11px;margin-right:.625rem;margin-top:-.75rem;display:flex;flex-wrap:wrap-reverse;justify-content:flex-end}.collapsed-pieces-holder{margin-right:0;margin-top:0;display:flex;--tw-rotate:0deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));overflow:hidden;overflow-y:visible}.collapsed-pieces-holder,.collapsed-pieces-holder.collapsed{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s;transition-duration:.5s}.collapsed-pieces-holder.collapsed{width:0;flex-wrap:nowrap}.collapsed-pieces-holder.expanded{flex-wrap:wrap}.collapsed-pieces-holder+button svg{--tw-rotate:0deg}.collapsed-pieces-holder+button svg,.collapsed-pieces-holder.collapsed+button svg{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s;transition-duration:.5s}.collapsed-pieces-holder.collapsed+button svg{--tw-rotate:360deg}.snippet{margin:.625rem .625rem .625rem 5px;overflow:hidden;border-radius:5px;background-color:var(--background-primary-alt);padding:.625rem;--tw-shadow:0px 4px 8px 0px #000c;--tw-shadow-colored:0px 4px 8px 0px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.snippet-content-parent{cursor:pointer}.snippet_line_number{color:var(--text-faint);font-family:Consolas,monospace}.gpt-input-textarea::-webkit-scrollbar,.snippet_pre::-webkit-scrollbar{display:none}.snippet_pre{margin-top:0;display:inline-block;-webkit-user-select:text;-moz-user-select:text;user-select:text;overflow-x:scroll}.pieces-parent::-webkit-scrollbar{display:none}.pieces-parent{position:relative;height:auto;max-height:210px;overflow:hidden;overflow-y:scroll;white-space:nowrap;border-radius:5px;font-size:var(--code-size)}#editParent{max-height:400px}.rawCode::-webkit-scrollbar{display:none}.rawCode{z-index:0;margin-left:35px;margin-right:1px;overflow-x:scroll;padding-right:25px}.lineNums{position:absolute;top:0;z-index:1;width:-moz-fit-content;width:fit-content;white-space:nowrap;padding-left:7px;text-align:right}.vertBreak{padding-left:5px}.buttonDiv{margin-top:15.5px;display:flex;flex-wrap:nowrap;justify-content:flex-end}.footerDiv{display:flex;justify-content:space-between}.button,.button_copy,.button_delete,.button_delete_modal,.button_refresh{cursor:pointer;padding-left:.75rem;padding-right:.75rem}.button_delete{margin-top:15.5px;--tw-text-opacity:1;color:rgb(244 67 54/var(--tw-text-opacity));opacity:.9;background:none!important;pointer-events:painted}.button_delete_modal{margin-right:0;margin-top:-.5rem;height:2.5rem;width:5rem;border-radius:10%;--tw-bg-opacity:1!important;background-color:rgb(244 67 54/var(--tw-bg-opacity))!important;font-size:medium;--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity));pointer-events:painted}.button_delete_modal_title{--tw-text-opacity:1;color:rgb(244 67 54/var(--tw-text-opacity))}.button_refresh{right:-7px;top:30px;margin-right:0;margin-top:0;cursor:pointer;align-self:flex-end;border-style:none;background-color:initial;font-size:1.25rem;line-height:1.75rem;font-weight:700;outline:2px solid #0000;outline-offset:2px;pointer-events:painted}.title_div{position:sticky;z-index:999;margin-bottom:5px;display:flex;align-content:center;justify-content:space-between;overflow:hidden}.sort-dropdown{margin:0;width:121px;cursor:pointer}.sort-dropdown:focus{border-color:none;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow);background:var(--interactive-normal)!important}.search-box-div{position:sticky;left:0;top:30px;z-index:999;margin-bottom:6px;display:flex}.input-search{margin-right:.5rem;margin-top:3px;height:46px;flex-grow:1;overflow-x:hidden;border-radius:.375rem;border-bottom:1px #ffffff80;border-style:none;padding:.625rem 2.5rem .625rem .625rem;font-size:1.125rem;line-height:1.75rem;letter-spacing:0;--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity))}.input-search,.input-search:hover{background-color:initial;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.5s;transition-timing-function:cubic-bezier(0,.11,.35,1.3)}.input-search:hover{width:250px;border-radius:.375rem;border-bottom:1px #ffffff80;border-style:solid}.input-search{outline:none;font:caption!important}.input-search::-moz-placeholder{font-size:1.125rem;line-height:1.75rem;font-size:small;font-weight:100;letter-spacing:0;color:#ffffff80}.input-search::placeholder{font-size:1.125rem;line-height:1.75rem;font-size:small;font-weight:100;letter-spacing:0;color:#ffffff80}.settings_divider{margin-top:5px;margin-bottom:1.25rem}.settings_external_links_section{display:flex;justify-content:space-around;padding:0 .625rem}.settings_external_links_section img{width:auto;cursor:pointer}.onboarding_image,.settings_external_links{-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.onboarding_image{pointer-events:none;margin-top:0;margin-bottom:0;margin-left:15px;height:800px;width:500px}.opening-div{margin-left:0;margin-top:0;height:-moz-fit-content;height:fit-content}.button-div{margin-top:0;margin-bottom:0;display:flex;justify-content:center}.snippet-container{background-color:var(--background-modifier)}.last-snippet{border-bottom-right-radius:5%;border-bottom-left-radius:5%;padding-bottom:3px;border-bottom:none!important}.first-snippet,.only-snippet{border-top-left-radius:5%;border-top-right-radius:5%}.only-snippet{border-bottom-right-radius:5%;border-bottom-left-radius:5%;border-bottom-color:none;padding-bottom:3px}.list-view{display:flex;flex-direction:column;background-color:var(--background-modifier)}.list-view,.list-view:hover{border-bottom-width:1px;border-bottom-color:var(--background-modifier-border)}.list-view:hover{background-color:var(--background-primary)}.list-view{border-bottom-style:solid}.list-title-div{margin:.375rem .375rem -.375rem;display:flex;justify-content:space-between;align-items:top}.list-title-div img{margin-right:.125rem;margin-top:.875rem;margin-bottom:0;height:1.25rem;width:1.25rem}.list-title-wrapper{display:flex;overflow:auto}.list-title-div h4{margin-top:.75rem;margin-bottom:.75rem;font-size:medium;color:var(--text-primary);-webkit-line-clamp:2}.list-body,.list-title-div h4{overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-box-orient:vertical}.list-body{margin-bottom:.625rem;max-height:4rem;padding-left:.875rem;padding-right:.875rem;font-size:small;color:var(--text-muted);-webkit-line-clamp:3}.list-button-container{margin-left:11px;display:flex;align-items:center}.list-button-input{position:absolute;top:-7px;left:.5rem;z-index:-1;margin-top:-29.5px;margin-left:.125rem;display:block;height:22px;width:87px;cursor:pointer;opacity:0}.list-button-container span{z-index:1;margin-left:.25rem;cursor:pointer;font-size:small;color:var(--text-primary)}.settings-div{margin-top:.75rem;display:flex;align-items:center;justify-content:center}.settings-div img{pointer-events:none;height:auto;width:auto;max-width:300px;flex-basis:100%;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.loading-div{flex-direction:column}.loading-div,.loading-div-row{margin-top:30px;display:flex;align-items:center;justify-content:center}.loading-div-row{flex-direction:row}.loading-div-col{display:flex;flex-direction:column;align-items:center;justify-content:center}.loading-div-button{display:flex;width:100%;flex-direction:row;justify-content:center;text-align:center}.loading-div-button button{cursor:pointer}.loading-div img{height:auto;width:auto;max-width:200px;flex-basis:100%}.loading-div h4{margin-top:.75rem;height:auto;width:auto;text-align:center;font-size:small}.new-div{margin-top:50px;display:flex;align-items:center;justify-content:center}.new-div img{height:auto;width:auto;max-width:200px;flex-basis:100%}.new-div h4{margin-top:-.625rem;margin-bottom:26px;height:auto;width:auto;max-width:219px;text-align:left;font-size:small}.expand-icon{position:absolute;right:0;top:0;height:22px;width:22px;cursor:pointer;border-radius:7px;background-color:var(--background-primary-alt);padding:.125rem}.expand-wrapper{position:sticky;top:0}@keyframes bouncing-loader{to{opacity:.1;transform:translate3d(0,-4px,0)}}.bouncing-loader,.refresh-bouncing-loader,.share-code-bouncing-loader{margin-top:-5px;margin-left:.125rem;display:flex;height:31px;width:39px;justify-content:center}.refresh-bouncing-loader{margin-top:-.125rem}.share-code-bouncing-loader{margin-right:5px}.bouncing-loader>div,.refresh-bouncing-loader>div,.share-code-bouncing-loader>div{margin:18px .1rem 0;height:.5rem;width:.5rem;animation:bouncing-loader .5s infinite alternate;border-radius:50%;background:var(--background-modifier-border-focus)}.bouncing-loader>div:nth-child(2),.refresh-bouncing-loader>div:nth-child(2),.share-code-bouncing-loader>div:nth-child(2){animation-delay:.2s}.bouncing-loader>div:nth-child(3),.refresh-bouncing-loader>div:nth-child(3),.share-code-bouncing-loader>div:nth-child(3){animation-delay:.4s}div[theme=dark] button{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity));--tw-text-opacity:1;color:rgb(0 0 0/var(--tw-text-opacity))}div[theme=light] button{--tw-bg-opacity:1;background-color:rgb(0 0 0/var(--tw-bg-opacity));--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity))}.edit-form-row{display:flex;width:100%;flex-direction:row;justify-content:center}.edit-form-desc{padding-left:5px;padding-right:.5rem}.justify-left{justify-content:left}.edit-form-col{margin:.5rem;display:flex;width:100%;flex-direction:column}.col-small{width:-moz-fit-content;width:fit-content}.edit-form{display:flex;width:100%;max-width:550px;flex-direction:column}.edit-title-input{font-weight:600;background:#0000!important}.edit-dropdown{max-height:50px;cursor:pointer;overflow-y:scroll;text-align:center}.edit-dropdown,.edit-dropdown:focus{border-width:var(--input-border-width);border-style:solid;border-color:var(--background-modifier-border)}.edit-dropdown:focus{--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.edit-dropdown,.edit-dropdown:focus{background:#0000!important}.edit-text,.edit-text-title{margin-top:.625rem;margin-bottom:.625rem;font-size:smaller;opacity:.8}.edit-text-title{margin-bottom:0;font-size:x-large;opacity:.9}.verticalAlign{align-items:center}.delTitle{color:rgb(244 67 54/var(--tw-text-opacity));opacity:.8}.delTitle,nav{--tw-text-opacity:1}nav{position:absolute;left:0;top:0;z-index:99999999;display:flex;height:2.5rem;width:100%;justify-content:space-evenly;color:rgb(150 240 177/var(--tw-text-opacity));background:#0000}nav a{padding:.625rem;font-size:1.4rem;--tw-text-opacity:1;color:rgb(128 128 128/var(--tw-text-opacity));text-decoration-line:none}.content{height:100%;width:750px}.content,.item{display:flex}.item{width:250px;flex-direction:column;align-items:center;justify-content:center;row-gap:25px;font-family:bolder;font-size:3rem;line-height:1;--tw-text-opacity:1;color:rgb(0 0 0/var(--tw-text-opacity));background:var(--background-secondary)}.link{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s;transition-duration:.3s}.wrapper{position:absolute;z-index:9999999;margin-top:-5px;margin-bottom:1.25rem;display:flex;width:-webkit-fill-available;justify-content:center;padding-right:15.5px}:root{--primary-color:#111;--secondary-color:#a8adb3}.tabs{position:relative;display:flex;height:1.75rem;width:100px;border-radius:.375rem;background-color:var(--interactive-normal);--tw-shadow-color:var(--input-shadow);--tw-shadow:var(--tw-shadow-colored)}.tabs .aiSVG{margin-left:.75rem;height:1.75rem;width:1.75rem}.tabs *{z-index:2}input[type=radio]{display:none}.tab{display:flex;height:100%;width:100%;cursor:pointer;align-items:center;justify-content:center;border-radius:.375rem;letter-spacing:.01em;transition-property:color;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s;transition-timing-function:ease-in;vertical-align:center}input[type=radio]+.tab svg,input[type=radio]:checked+.tab{--tw-text-opacity:1;color:rgb(107 107 107/var(--tw-text-opacity))}input[id=radio-1]:checked~.glider{--tw-translate-x:0px}input[id=radio-1]:checked~.glider,input[id=radio-2]:checked~.glider{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}input[id=radio-2]:checked~.glider{--tw-translate-x:101%}.glider{position:absolute;left:0;top:0;z-index:1;display:flex;height:100%;width:50%;border-radius:.375rem;border-width:1px;border-style:solid;border-color:var(--text-faint);background-color:var(--text-muted);--tw-shadow-color:var(--input-shadow);--tw-shadow:var(--tw-shadow-colored);transition-property:.25s;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s;transition-duration:ease-out}.glider-light{background-color:var(--background-modifier-box-shadow)}.tabs svg{pointer-events:none;color:var(--text-normal)}.gpt-row,.gpt-row-full,.gpt-row-response,.gpt-row-small{display:flex;max-width:100%;flex-direction:row}.gpt-col,.gpt-col-reverse,.gpt-col-small{display:flex;min-width:100%;max-width:100%;flex-direction:column}.gpt-col-small{min-width:0}.gpt-col-reverse{flex-direction:column-reverse}.gpt-container{margin:0;display:flex;height:100%}.gpt-input{margin-top:1rem;margin-bottom:25px;height:-moz-fit-content;height:fit-content;align-items:flex-start;justify-content:center;border-radius:10px;border-width:1px;background-color:var(--background-secondary);padding-top:1rem;padding-bottom:1rem;padding-left:1rem;--tw-shadow:0px 4px 8px 0px #000c;--tw-shadow-colored:0px 4px 8px 0px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.gpt-input-textarea{display:block;max-height:100px;width:100%;cursor:text;resize:none;overflow:hidden;overflow-y:scroll;overflow-wrap:break-word;padding-right:3rem;text-align:start;line-height:1.25rem;color:inherit;font-family:inherit}.gpt-input-textarea[contenteditable]:empty:before{--tw-text-opacity:1;color:rgb(128 128 128/var(--tw-text-opacity));--tw-content:"Paste some code or ask a technical question...";content:var(--tw-content)}.gpt-text-content{margin-top:-18px;min-height:50%;flex:1 1 0%;overflow-y:scroll;border-radius:10px;padding:26px 26px 0;word-wrap:break-word}.gpt-text-area{height:100%;max-height:none;overflow-y:scroll}.gpt-text-div{margin-top:34px;display:flex;flex-basis:100%;flex-direction:column;overflow-y:scroll;border-radius:10px;background-color:var(--background-secondary);--tw-shadow:0px 4px 8px 0px #000c;--tw-shadow-colored:0px 4px 8px 0px var(--tw-shadow-color)}.gpt-text-div,.gpt-text-div-light{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.gpt-text-div-light{--tw-shadow:0px 2px 4px 0px #000c;--tw-shadow-colored:0px 2px 4px 0px var(--tw-shadow-color)}.gpt-text-area::-webkit-scrollbar,.gpt-text-content::-webkit-scrollbar,.gpt-text-div::-webkit-scrollbar{display:none}.gpt-text-response{margin-top:0;margin-bottom:.625rem;width:-moz-fit-content;width:fit-content;-webkit-user-select:text;-moz-user-select:text;user-select:text;border-radius:10px;padding:.75rem;text-align:left;font-size:.875rem;line-height:1.25rem;word-break:break-word}.gpt-right-align{justify-content:flex-end}.gpt-left-align{justify-content:flex-start}.gpt-query{margin-right:.5rem;background-color:var(--interactive-accent)}.gpt-response{min-width:0;background-color:var(--interactive-normal)}.gpt-img,.gpt-img-small{display:flex;min-height:30px;min-width:30px;justify-content:center}.gpt-icon{display:flex;height:30px;width:30px;align-items:center}.gpt-icon-note{height:.875rem;width:.875rem}.gpt-icon-drift{margin-right:-.75rem}.gpt-icon-drift svg{position:static}.aiSVG,.userSVG{margin-top:7px;color:var(--text-muted);width:30px!important;height:30px!important}.sendSVG{right:23px;bottom:54px;height:25px;width:25px;--tw-text-opacity:1;color:rgb(128 128 128/var(--tw-text-opacity))}.gpt-img-small{margin-bottom:19px;margin-top:auto;height:0;min-height:0;width:0;cursor:pointer}.gpt-cancel{right:0;bottom:0;margin-right:.625rem;margin-top:5px;margin-bottom:7px;--tw-text-opacity:1;color:rgb(128 128 128/var(--tw-text-opacity))}.gpt-cancel,.gpt-context{position:sticky;width:-moz-fit-content;width:fit-content;cursor:pointer;align-self:flex-end;font-size:smaller}.gpt-context{margin-right:7px;margin-top:.625rem;color:var(--text-normal)}.gpt-text-intro{display:flex;height:100%;width:100%;align-items:center;justify-content:center;padding-left:.375rem;padding-right:.375rem}.gpt-text-intro-content{margin-top:0;text-align:center;color:var(--text-muted)}.gpt-text-intro-title{margin-bottom:.5rem;font-size:32px;font-weight:600;color:var(--text-normal)}.gpt-text-intro-title-div{padding-left:10%;padding-right:10%}.gpt-parent{height:100%}.hint-btn,.hint-btn-note{margin:.25rem .125rem;display:inline-flex;cursor:pointer;align-items:center;overflow:hidden;white-space:normal;border-radius:1rem;border-color:none;padding:1rem .375rem;text-align:center;font-size:.75rem;line-height:1rem;color:var(--text-normal);text-decoration-line:none;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow);word-break:break-word}.hint-btn-note{background-color:var(--background-modifier-border-hover)}.hint-btn-note:hover{background-color:var(--background-modifier-hover)}.hint-btn{background-color:var(--interactive-normal)}.hint-btn:hover{background-color:var(--interactive-hover)}#gpt-hints-container{justify-content:center;padding-left:1.25rem;padding-right:1.25rem}.hint-title{margin:.125rem .125rem .125rem .625rem;justify-content:center;align-self:flex-start;font-size:.75rem;line-height:1rem;color:var(--text-muted)}.hint-list{margin-left:.5rem;margin-right:.5rem;max-height:77px}.hint-list,.hint-list-note{overflow:hidden;overflow-y:scroll;border-radius:5px}.hint-list-note{margin-top:-.75rem;margin-bottom:-.5rem;max-height:82px;border-color:var(--background-modifier-border)}.hint-list-note::-webkit-scrollbar,.hint-list::-webkit-scrollbar{display:none}.hint-btn-text{margin-right:.25rem;text-overflow:ellipsis;padding-left:1px;text-align:center;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.gpt-query pre code,.gpt-response pre code,.hint-btn-text{width:100%}.gpt-query pre code,.gpt-response pre code{margin-top:.5rem;margin-bottom:.75rem;min-height:20px;-webkit-user-select:text;-moz-user-select:text;user-select:text;overflow:hidden;white-space:pre-wrap;border-radius:5px;background-color:var(--background-primary-alt);padding-left:.25rem;padding-right:.25rem;--tw-shadow:0px 2px 4px 0px #000c;--tw-shadow-colored:0px 2px 4px 0px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.gpt-response-margin-delete{margin:0}.gpt-response-button-div{margin-right:-14px;margin-bottom:-13px}.gpt-img-logo{height:4rem;padding-bottom:.5rem;opacity:.8}p.gpt-response-margin-delete code{display:inline;white-space:pre-line;border-radius:5px;background-color:var(--background-modifier-active-hover);padding-left:.25rem;padding-right:.25rem}.gpt-user-image{margin-top:5px;height:1.5rem;width:1.5rem;border-radius:50%}.hint-title-note{font-size:.75rem;line-height:1rem;font-weight:400;color:var(--text-muted)}.gpt-rel-wrap{flex-wrap:wrap}.gpt-hint-col{border-radius:5px}.gpt-hint-row{padding-top:7px}.gpt-send-active{color:var(--interactive-accent)}.gpt-send-unactive{--tw-text-opacity:1;color:rgb(128 128 128/var(--tw-text-opacity))}.discovery-div{margin-left:.25rem;justify-content:flex-end;white-space:nowrap}.discovery-div,.discovery-div-inner{display:flex;flex-wrap:nowrap;align-items:center;overflow:hidden}.discovery-title{color:var(--text-muted)}.discovery-break{padding-left:.5rem}.discovery-checkbox{margin-left:13px!important;margin-right:0!important;margin-top:22px!important}.discovery-seperator{margin-left:26px;margin-right:0;margin-top:1rem}.discovery-div-parent{position:sticky;height:0;width:0}.context-row{display:flex;width:100%;flex-direction:row;justify-content:space-between}.context-col{display:flex;height:100%;flex-direction:column}.context-parent{margin-top:.875rem;display:flex;max-height:600px;min-height:600px;width:100%;flex-direction:row;overflow:hidden}.context-preview{margin-top:-9px;overflow:hidden;overflow-x:scroll;overflow-y:scroll;padding:0 .5rem .5rem;color:var(--text-muted)}.context-list-container::-webkit-scrollbar,.context-preview::-webkit-scrollbar{display:none}.context-preview-title{margin:0;font-size:1.25rem;line-height:1.75rem;color:var(--text-muted)}.context-preview-title-parent{margin-bottom:.625rem;border-bottom-width:1px;border-bottom-color:var(--text-faint);padding:.25rem;border-bottom-style:solid}.context-list-container{margin-right:.25rem;max-height:592px;min-width:40%;max-width:40%;overflow:hidden;overflow-y:scroll;color:var(--text-muted)}.context-preview-container{margin-top:22px;margin-right:5px;margin-bottom:.5rem;max-height:570px;min-height:570px;min-width:60%;max-width:60%;border-radius:.5rem;padding:.5rem;font-size:smaller;--tw-shadow:0px 2px 4px 0px #000c;--tw-shadow-colored:0px 2px 4px 0px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}#parentFileUL,ul{list-style-type:none!important}#parentFileUL{margin:0;width:-webkit-fill-available;padding:0}.caret{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;font-weight:300;color:var(--text-accent)}.caret:before{margin-right:3px;display:inline-block;color:var(--text-muted);opacity:.9;--tw-content:"\25B6";content:var(--tw-content)}.caret:hover{color:var(--text-accent-hover)}.caret-down:before{--tw-rotate:90deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.nested{margin-left:-30px;display:none}.active{display:block}.context-list-div{display:flex;flex-direction:row;justify-content:space-between;white-space:pre}.context-list-checkbox{margin-left:.25rem!important;margin-top:3px!important;border-width:.5px!important;border-style:dashed!important;border-color:var(--checkbox-border-color)!important}.context-list-checkbox:hover{cursor:pointer!important;border-width:1px!important;border-style:solid!important;border-color:var(--text-accent-hover)!important}.context-title{margin:-1px 0 -1.5rem;padding:0;font-size:x-large;font-weight:500;color:var(--text-normal)}.context-list-div span:hover{cursor:pointer;color:var(--text-accent-hover)}.context-list-span{display:inline-block;max-width:170px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:100}.context-background{position:absolute;z-index:2;height:1.25rem;width:206px;overflow:hidden;background-color:var(--modal-background)}.context-root{position:absolute;z-index:3;font-weight:200}.context-root span{font-weight:500}.context-hide{padding-top:18px}.context-list-item{padding-top:1px;padding-bottom:1px}.context-display-width{width:inherit}.context-shadow{--tw-shadow:0px 2px 4px 0px #000c;--tw-shadow-colored:0px 2px 4px 0px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.context-preview-default{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.enrich-btn-row{display:flex;flex-direction:row;justify-content:space-between;padding-left:12rem;padding-right:12rem}.enrich-img{margin-bottom:30px;display:flex;flex-direction:row;justify-content:center}.enrich-confirm-btn,.enrich-deny-btn{cursor:pointer}.search-div{position:sticky;top:30px;left:0;z-index:9999;margin-bottom:3.5rem}.loading-bar{z-index:9999;margin-top:0;display:flex;height:5px;border-radius:5px;background-color:var(--interactive-accent)}.loading-bar:after{top:0;left:0;display:block;height:100%;width:0;content:"";transition:width 2s ease}.ask-row{display:flex;flex-direction:row;border-radius:.25rem}.ask-col{display:flex;flex-direction:column}.ask-input{width:100%;word-wrap:break-word;word-break:break-all}.ask-send-svg{margin-top:1px;margin-right:.5rem}.ask-selection{margin-top:0;margin-bottom:.5rem;max-height:300px;overflow-y:scroll;white-space:pre-wrap;border-radius:.25rem;padding:.5rem;--tw-shadow:0px 4px 8px 0px #000c;--tw-shadow-colored:0px 4px 8px 0px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow);color:var(--text-muted);word-wrap:break-word;width:-webkit-fill-available}.ask-modal-title{margin:0}.ask-input-row{margin-top:.5rem;max-height:150px;min-height:25px;border-radius:5px;padding-top:.5rem;padding-left:1rem;--tw-shadow:0px 4px 8px 0px #000c;--tw-shadow-colored:0px 4px 8px 0px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.ask-col-input{flex-grow:1;overflow-y:scroll;padding-top:1.5px}.ask-col-input::-webkit-scrollbar,.ask-selection::-webkit-scrollbar{display:none}.row{flex-direction:row}.col,.row{display:flex}.col{flex-direction:column}.width-full{width:100%}.width-max{min-width:100%;max-width:100%}.v-align-center{align-items:center}.h-align-center{justify-content:center}.annotation-form::-webkit-scrollbar,.annotation-text-body::-webkit-scrollbar{display:none}.annotation-form{display:flex;max-height:550px;width:100%;max-width:550px;flex-direction:column;overflow-y:scroll}.annotation-body{padding:.75rem}.annotation-add-body,.annotation-body{display:flex;border-radius:.5rem;border-width:1.5px;border-style:solid;border-color:var(--background-secondary-alt);background-color:var(--background-secondary)}.annotation-add-body{padding:.25rem}.annotation-text-body{margin-bottom:1rem;cursor:text;resize:none;overflow:hidden;overflow-y:scroll;text-align:start}.annotation-add-text-body,.annotation-text-body{display:block;border-style:none;background-color:initial;overflow-wrap:break-word}.annotation-add-text-body{cursor:pointer;text-align:center;font-weight:500}.annotation-text-body[contenteditable]:empty:before{--tw-text-opacity:1;color:rgb(128 128 128/var(--tw-text-opacity));--tw-content:"Add a description or a comment...";content:var(--tw-content)}.annotation-text-height-max{max-height:100px}.annotation-text-height-min{min-height:-moz-fit-content;min-height:fit-content}.annotation-metadata{align-items:center;justify-content:space-between;font-size:.75rem;line-height:1rem;font-weight:500;--tw-text-opacity:1;color:rgb(128 128 128/var(--tw-text-opacity))}.annotation-metadata-left{display:flex;align-items:center}.annotation-metadata-left svg{margin-right:.25rem;height:.75rem;width:auto}.annotation-metadata-left-btn{margin-left:.5rem;display:flex;--tw-scale-x:1.1;--tw-scale-y:1.1;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));cursor:pointer}.annotation-delete svg{color:#ff4343}.annotation-seperator{margin-left:1rem}.annotation-seperator div{height:1rem;border-color:var(--background-secondary-alt);border-left-style:solid;border-left-width:1.5px}.annotation-action-row{display:flex;flex-direction:row}@keyframes enterAnimation{0%{opacity:0}to{opacity:1}}@keyframes exitAnimation{0%{opacity:1}to{opacity:0}}.hidden-in{animation:enterAnimation .3s ease forwards}.hidden-out{animation:exitAnimation .3s ease backwards}.actions-hidden{opacity:0} \ No newline at end of file +*,::backdrop,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }.container{width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}.collapse{visibility:collapse}.static{position:static}.absolute{position:absolute}.mx-1{margin-left:.25rem;margin-right:.25rem}.my-1{margin-top:.25rem;margin-bottom:.25rem}.my-2{margin-top:.5rem;margin-bottom:.5rem}.mb-1{margin-bottom:.25rem}.ml-2{margin-left:.5rem}.mr-1{margin-right:.25rem}.mr-2{margin-right:.5rem}.mr-3{margin-right:.75rem}.mt-2{margin-top:.5rem}.mt-\[-8px\]{margin-top:-8px}.block{display:block}.flex{display:flex}.table{display:table}.hidden{display:none}.h-full{height:100%}.min-h-\[32px\]{min-height:32px}.w-1\/2{width:50%}.w-fit{width:-moz-fit-content;width:fit-content}.w-full{width:100%}.cursor-pointer{cursor:pointer}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-end{justify-content:flex-end}.justify-between{justify-content:space-between}.text-center{text-align:center}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.text-\[var\(--text-accent\)\]{color:var(--text-accent)}.text-\[var\(--text-faint\)\]{color:var(--text-faint)}.underline{text-decoration-line:underline}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.search-background{position:sticky;top:-21px;left:0;z-index:998;margin-top:-145px;margin-bottom:-14px;height:131px;flex-grow:1;background-color:var(--background-secondary)}.code-view{z-index:-1;height:auto;border-bottom-width:var(--background-modifier-border);border-bottom-color:solid}.code-view:last-child{border-bottom-color:none}.code-title-div{position:relative;margin-top:0;margin-bottom:0;display:flex;height:50px;flex-wrap:wrap;vertical-align:middle;justify-content:left}.code-title-div h1{position:absolute;left:38px;top:13.2px;margin-top:.125rem;height:30px;font-size:15px}.code-title-div img{position:absolute;left:7px;top:17.3px;margin-top:-3px;margin-right:.625rem;height:22px;width:22px}.code-title-div span{position:absolute;right:-1rem;margin-right:1.75rem;margin-top:.875rem;height:30px;font-size:17px}.code-button-input{z-index:997;order:-1;margin:0!important;display:block;height:49px!important;flex-grow:1;cursor:pointer;opacity:0}.code-title-div:hover{background:var(--background-primary)!important}.save-to-pieces-btn{margin-right:5px;margin-bottom:5px;height:29px;width:42px;cursor:pointer;align-items:left;background:none}.save-to-pieces-holder{margin-bottom:-11px;margin-right:.625rem;margin-top:-.75rem;display:flex;flex-wrap:wrap-reverse;justify-content:flex-end}.collapsed-pieces-holder{margin-right:0;margin-top:0;display:flex;--tw-rotate:0deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));overflow:hidden;overflow-y:visible}.collapsed-pieces-holder,.collapsed-pieces-holder.collapsed{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s;transition-duration:.5s}.collapsed-pieces-holder.collapsed{width:0;flex-wrap:nowrap}.collapsed-pieces-holder.expanded{flex-wrap:wrap}.collapsed-pieces-holder+button svg{--tw-rotate:0deg}.collapsed-pieces-holder+button svg,.collapsed-pieces-holder.collapsed+button svg{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s;transition-duration:.5s}.collapsed-pieces-holder.collapsed+button svg{--tw-rotate:360deg}.snippet{margin:.625rem .625rem .625rem 5px;overflow:hidden;border-radius:5px;background-color:var(--background-primary-alt);padding:.625rem;--tw-shadow:0px 4px 8px 0px #000c;--tw-shadow-colored:0px 4px 8px 0px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.snippet-content-parent{cursor:pointer}.snippet_line_number{color:var(--text-faint);font-family:Consolas,monospace}.gpt-input-textarea::-webkit-scrollbar,.snippet_pre::-webkit-scrollbar{display:none}.snippet_pre{margin-top:0;display:inline-block;-webkit-user-select:text;-moz-user-select:text;user-select:text;overflow-x:scroll}.pieces-parent::-webkit-scrollbar{display:none}.pieces-parent{position:relative;height:auto;max-height:210px;overflow:hidden;overflow-y:scroll;white-space:nowrap;border-radius:5px;font-size:var(--code-size)}#editParent{max-height:400px}.rawCode::-webkit-scrollbar{display:none}.rawCode{z-index:0;margin-left:35px;margin-right:1px;overflow-x:scroll;padding-right:25px}.lineNums{position:absolute;top:0;z-index:1;width:-moz-fit-content;width:fit-content;white-space:nowrap;padding-left:7px;text-align:right}.vertBreak{padding-left:5px}.buttonDiv{margin-top:15.5px;display:flex;flex-wrap:nowrap;justify-content:flex-end}.footerDiv{display:flex;justify-content:space-between}.button,.button_copy,.button_delete,.button_delete_modal,.button_refresh{cursor:pointer;padding-left:.75rem;padding-right:.75rem}.button_delete{margin-top:15.5px;--tw-text-opacity:1;color:rgb(244 67 54/var(--tw-text-opacity));opacity:.9;background:none!important;pointer-events:painted}.button_delete_modal{margin-right:0;margin-top:-.5rem;height:2.5rem;width:5rem;border-radius:10%;--tw-bg-opacity:1!important;background-color:rgb(244 67 54/var(--tw-bg-opacity))!important;font-size:medium;--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity));pointer-events:painted}.button_delete_modal_title{--tw-text-opacity:1;color:rgb(244 67 54/var(--tw-text-opacity))}.button_refresh{right:-7px;top:30px;margin-right:0;margin-top:0;cursor:pointer;align-self:flex-end;border-style:none;background-color:initial;font-size:1.25rem;line-height:1.75rem;font-weight:700;outline:2px solid #0000;outline-offset:2px;pointer-events:painted}.title_div{position:sticky;z-index:999;margin-bottom:5px;display:flex;align-content:center;justify-content:space-between;overflow:hidden}.sort-dropdown{margin:0;width:121px;cursor:pointer}.sort-dropdown:focus{border-color:none;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow);background:var(--interactive-normal)!important}.search-box-div{position:sticky;left:0;top:30px;z-index:999;margin-bottom:6px;display:flex}.input-search{margin-right:.5rem;margin-top:3px;height:46px;flex-grow:1;overflow-x:hidden;border-radius:.375rem;border-bottom:1px #ffffff80;border-style:none;padding:.625rem 2.5rem .625rem .625rem;font-size:1.125rem;line-height:1.75rem;letter-spacing:0;--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity))}.input-search,.input-search:hover{background-color:initial;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.5s;transition-timing-function:cubic-bezier(0,.11,.35,1.3)}.input-search:hover{width:250px;border-radius:.375rem;border-bottom:1px #ffffff80;border-style:solid}.input-search{outline:none;font:caption!important}.input-search::-moz-placeholder{font-size:1.125rem;line-height:1.75rem;font-size:small;font-weight:100;letter-spacing:0;color:#ffffff80}.input-search::placeholder{font-size:1.125rem;line-height:1.75rem;font-size:small;font-weight:100;letter-spacing:0;color:#ffffff80}.settings_divider{margin-top:5px;margin-bottom:1.25rem}.settings_external_links_section{display:flex;justify-content:space-around;padding:0 .625rem}.settings_external_links_section img{width:auto;cursor:pointer}.onboarding_image,.settings_external_links{-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.onboarding_image{pointer-events:none;margin-top:0;margin-bottom:0;margin-left:15px;height:800px;width:500px}.opening-div{margin-left:0;margin-top:0;height:-moz-fit-content;height:fit-content}.button-div{margin-top:0;margin-bottom:0;display:flex;justify-content:center}.snippet-container{background-color:var(--background-modifier)}.last-snippet{border-bottom-right-radius:5%;border-bottom-left-radius:5%;padding-bottom:3px;border-bottom:none!important}.first-snippet,.only-snippet{border-top-left-radius:5%;border-top-right-radius:5%}.only-snippet{border-bottom-right-radius:5%;border-bottom-left-radius:5%;border-bottom-color:none;padding-bottom:3px}.list-view{display:flex;flex-direction:column;background-color:var(--background-modifier)}.list-view,.list-view:hover{border-bottom-width:1px;border-bottom-color:var(--background-modifier-border)}.list-view:hover{background-color:var(--background-primary)}.list-view{border-bottom-style:solid}.list-title-div{margin:.375rem .375rem -.375rem;display:flex;justify-content:space-between;align-items:top}.list-title-div img{margin-right:.125rem;margin-top:.875rem;margin-bottom:0;height:1.25rem;width:1.25rem}.list-title-wrapper{display:flex;overflow:auto}.list-title-div h4{margin-top:.75rem;margin-bottom:.75rem;font-size:medium;color:var(--text-primary);-webkit-line-clamp:2}.list-body,.list-title-div h4{overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-box-orient:vertical}.list-body{margin-bottom:.625rem;max-height:4rem;padding-left:.875rem;padding-right:.875rem;font-size:small;color:var(--text-muted);-webkit-line-clamp:3}.list-button-container{margin-left:11px;display:flex;align-items:center}.list-button-input{position:absolute;top:-7px;left:.5rem;z-index:-1;margin-top:-29.5px;margin-left:.125rem;display:block;height:22px;width:87px;cursor:pointer;opacity:0}.list-button-container span{z-index:1;margin-left:.25rem;cursor:pointer;font-size:small;color:var(--text-primary)}.settings-div{margin-top:.75rem;display:flex;align-items:center;justify-content:center}.settings-div img{pointer-events:none;height:auto;width:auto;max-width:300px;flex-basis:100%;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.loading-div{flex-direction:column}.loading-div,.loading-div-row{margin-top:30px;display:flex;align-items:center;justify-content:center}.loading-div-row{flex-direction:row}.loading-div-col{display:flex;flex-direction:column;align-items:center;justify-content:center}.loading-div-button{display:flex;width:100%;flex-direction:row;justify-content:center;text-align:center}.loading-div-button button{cursor:pointer}.loading-div img{height:auto;width:auto;max-width:200px;flex-basis:100%}.loading-div h4{margin-top:.75rem;height:auto;width:auto;text-align:center;font-size:small}.new-div{margin-top:50px;display:flex;align-items:center;justify-content:center}.new-div img{height:auto;width:auto;max-width:200px;flex-basis:100%}.new-div h4{margin-top:-.625rem;margin-bottom:26px;height:auto;width:auto;max-width:219px;text-align:left;font-size:small}.expand-icon{position:absolute;right:0;top:0;height:22px;width:22px;cursor:pointer;border-radius:7px;background-color:var(--background-primary-alt);padding:.125rem}.expand-wrapper{position:sticky;top:0}@keyframes bouncing-loader{to{opacity:.1;transform:translate3d(0,-4px,0)}}.bouncing-loader,.refresh-bouncing-loader,.share-code-bouncing-loader{margin-top:-5px;margin-left:.125rem;display:flex;height:31px;width:39px;justify-content:center}.refresh-bouncing-loader{margin-top:-.125rem}.share-code-bouncing-loader{margin-right:5px}.bouncing-loader>div,.refresh-bouncing-loader>div,.share-code-bouncing-loader>div{margin:18px .1rem 0;height:.5rem;width:.5rem;animation:bouncing-loader .5s infinite alternate;border-radius:50%;background:var(--background-modifier-border-focus)}.bouncing-loader>div:nth-child(2),.refresh-bouncing-loader>div:nth-child(2),.share-code-bouncing-loader>div:nth-child(2){animation-delay:.2s}.bouncing-loader>div:nth-child(3),.refresh-bouncing-loader>div:nth-child(3),.share-code-bouncing-loader>div:nth-child(3){animation-delay:.4s}div[theme=dark] button{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity));--tw-text-opacity:1;color:rgb(0 0 0/var(--tw-text-opacity))}div[theme=light] button{--tw-bg-opacity:1;background-color:rgb(0 0 0/var(--tw-bg-opacity));--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity))}.edit-form-row{display:flex;width:100%;flex-direction:row;justify-content:center}.edit-form-desc{padding-left:5px;padding-right:.5rem}.justify-left{justify-content:left}.edit-form-col{margin:.5rem;display:flex;width:100%;flex-direction:column}.col-small{width:-moz-fit-content;width:fit-content}.edit-form{display:flex;width:100%;max-width:550px;flex-direction:column}.edit-title-input{font-weight:600;background:#0000!important}.edit-dropdown{max-height:50px;cursor:pointer;overflow-y:scroll;text-align:center}.edit-dropdown,.edit-dropdown:focus{border-width:var(--input-border-width);border-style:solid;border-color:var(--background-modifier-border)}.edit-dropdown:focus{--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.edit-dropdown,.edit-dropdown:focus{background:#0000!important}.edit-text,.edit-text-title{margin-top:.625rem;margin-bottom:.625rem;font-size:smaller;opacity:.8}.edit-text-title{margin-bottom:0;font-size:x-large;opacity:.9}.verticalAlign{align-items:center}.delTitle{color:rgb(244 67 54/var(--tw-text-opacity));opacity:.8}.delTitle,nav{--tw-text-opacity:1}nav{position:absolute;left:0;top:0;z-index:99999999;display:flex;height:2.5rem;width:100%;justify-content:space-evenly;color:rgb(150 240 177/var(--tw-text-opacity));background:#0000}nav a{padding:.625rem;font-size:1.4rem;--tw-text-opacity:1;color:rgb(128 128 128/var(--tw-text-opacity));text-decoration-line:none}.content{height:100%;width:750px}.content,.item{display:flex}.item{width:250px;flex-direction:column;align-items:center;justify-content:center;row-gap:25px;font-family:bolder;font-size:3rem;line-height:1;--tw-text-opacity:1;color:rgb(0 0 0/var(--tw-text-opacity));background:var(--background-secondary)}.link{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s;transition-duration:.3s}.wrapper{position:absolute;z-index:9999999;margin-top:-5px;margin-bottom:1.25rem;display:flex;width:-webkit-fill-available;justify-content:center;padding-right:15.5px}:root{--primary-color:#111;--secondary-color:#a8adb3}.tabs{position:relative;display:flex;height:1.75rem;width:100px;border-radius:.375rem;background-color:var(--interactive-normal);--tw-shadow-color:var(--input-shadow);--tw-shadow:var(--tw-shadow-colored)}.tabs .aiSVG{margin-left:.75rem;height:1.75rem;width:1.75rem}.tabs *{z-index:2}input[type=radio]{display:none}.tab{display:flex;height:100%;width:100%;cursor:pointer;align-items:center;justify-content:center;border-radius:.375rem;letter-spacing:.01em;transition-property:color;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s;transition-timing-function:ease-in;vertical-align:center}input[type=radio]+.tab svg,input[type=radio]:checked+.tab{--tw-text-opacity:1;color:rgb(107 107 107/var(--tw-text-opacity))}input[id=radio-1]:checked~.glider{--tw-translate-x:0px}input[id=radio-1]:checked~.glider,input[id=radio-2]:checked~.glider{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}input[id=radio-2]:checked~.glider{--tw-translate-x:101%}.glider{position:absolute;left:0;top:0;z-index:1;display:flex;height:100%;width:50%;border-radius:.375rem;border-width:1px;border-style:solid;border-color:var(--text-faint);background-color:var(--text-muted);--tw-shadow-color:var(--input-shadow);--tw-shadow:var(--tw-shadow-colored);transition-property:.25s;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s;transition-duration:ease-out}.glider-light{background-color:var(--background-modifier-box-shadow)}.tabs svg{pointer-events:none;color:var(--text-normal)}.gpt-row,.gpt-row-full,.gpt-row-response,.gpt-row-small{display:flex;max-width:100%;flex-direction:row}.gpt-col,.gpt-col-reverse,.gpt-col-small{display:flex;min-width:100%;max-width:100%;flex-direction:column}.gpt-col-small{min-width:0}.gpt-col-reverse{flex-direction:column-reverse}.gpt-container{margin:0;display:flex;height:100%}.gpt-input{margin-top:1rem;margin-bottom:25px;height:-moz-fit-content;height:fit-content;align-items:flex-start;justify-content:center;border-radius:10px;border-width:1px;background-color:var(--background-secondary);padding-top:1rem;padding-bottom:1rem;padding-left:1rem;--tw-shadow:0px 4px 8px 0px #000c;--tw-shadow-colored:0px 4px 8px 0px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.gpt-input-textarea{display:block;max-height:100px;width:100%;cursor:text;resize:none;overflow:hidden;overflow-y:scroll;overflow-wrap:break-word;padding-right:3rem;text-align:start;line-height:1.25rem;color:inherit;font-family:inherit}.gpt-input-textarea[contenteditable]:empty:before{--tw-text-opacity:1;color:rgb(128 128 128/var(--tw-text-opacity));--tw-content:"Paste some code or ask a technical question...";content:var(--tw-content)}.gpt-text-content{margin-top:-18px;min-height:50%;flex:1 1 0%;overflow-y:scroll;border-radius:10px;padding:26px 26px 0;word-wrap:break-word}.gpt-text-area{height:100%;max-height:none;overflow-y:scroll}.gpt-text-div{margin-top:34px;display:flex;flex-basis:100%;flex-direction:column;overflow-y:scroll;border-radius:10px;background-color:var(--background-secondary);--tw-shadow:0px 4px 8px 0px #000c;--tw-shadow-colored:0px 4px 8px 0px var(--tw-shadow-color)}.gpt-text-div,.gpt-text-div-light{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.gpt-text-div-light{--tw-shadow:0px 2px 4px 0px #000c;--tw-shadow-colored:0px 2px 4px 0px var(--tw-shadow-color)}.gpt-text-area::-webkit-scrollbar,.gpt-text-content::-webkit-scrollbar,.gpt-text-div::-webkit-scrollbar{display:none}.gpt-text-response{margin-top:0;margin-bottom:.625rem;width:-moz-fit-content;width:fit-content;-webkit-user-select:text;-moz-user-select:text;user-select:text;border-radius:10px;padding:.75rem;text-align:left;font-size:.875rem;line-height:1.25rem;word-break:break-word}.gpt-right-align{justify-content:flex-end}.gpt-left-align{justify-content:flex-start}.gpt-query{margin-right:.5rem;background-color:var(--interactive-accent)}.gpt-response{min-width:0;background-color:var(--interactive-normal)}.gpt-img,.gpt-img-small{display:flex;min-height:30px;min-width:30px;justify-content:center}.gpt-icon{display:flex;height:30px;width:30px;align-items:center}.gpt-icon-note{height:.875rem;width:.875rem}.gpt-icon-drift{margin-right:-.75rem}.gpt-icon-drift svg{position:static}.aiSVG,.userSVG{margin-top:7px;color:var(--text-muted);width:30px!important;height:30px!important}.sendSVG{right:23px;bottom:54px;height:25px;width:25px;--tw-text-opacity:1;color:rgb(128 128 128/var(--tw-text-opacity))}.gpt-img-small{margin-bottom:19px;margin-top:auto;height:0;min-height:0;width:0;cursor:pointer}.gpt-cancel{right:0;bottom:0;margin-right:.625rem;margin-top:5px;margin-bottom:7px;--tw-text-opacity:1;color:rgb(128 128 128/var(--tw-text-opacity))}.gpt-cancel,.gpt-context{position:sticky;width:-moz-fit-content;width:fit-content;cursor:pointer;align-self:flex-end;font-size:smaller}.gpt-context{margin-right:7px;margin-top:.625rem;color:var(--text-normal)}.gpt-text-intro{display:flex;height:100%;width:100%;align-items:center;justify-content:center;padding-left:.375rem;padding-right:.375rem}.gpt-text-intro-content{margin-top:0;text-align:center;color:var(--text-muted)}.gpt-text-intro-title{margin-bottom:.5rem;font-size:32px;font-weight:600;color:var(--text-normal)}.gpt-text-intro-title-div{padding-left:10%;padding-right:10%}.gpt-parent{height:100%}.hint-btn,.hint-btn-note{margin:.25rem .125rem;display:inline-flex;cursor:pointer;align-items:center;overflow:hidden;white-space:normal;border-radius:1rem;border-color:none;padding:1rem .375rem;text-align:center;font-size:.75rem;line-height:1rem;color:var(--text-normal);text-decoration-line:none;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow);word-break:break-word}.hint-btn-note{background-color:var(--background-modifier-border-hover)}.hint-btn-note:hover{background-color:var(--background-modifier-hover)}.hint-btn{background-color:var(--interactive-normal)}.hint-btn:hover{background-color:var(--interactive-hover)}#gpt-hints-container{justify-content:center;padding-left:1.25rem;padding-right:1.25rem}.hint-title{margin:.125rem .125rem .125rem .625rem;justify-content:center;align-self:flex-start;font-size:.75rem;line-height:1rem;color:var(--text-muted)}.hint-list{margin-left:.5rem;margin-right:.5rem;max-height:77px}.hint-list,.hint-list-note{overflow:hidden;overflow-y:scroll;border-radius:5px}.hint-list-note{margin-top:-.75rem;margin-bottom:-.5rem;max-height:82px;border-color:var(--background-modifier-border)}.hint-list-note::-webkit-scrollbar,.hint-list::-webkit-scrollbar{display:none}.hint-btn-text{margin-right:.25rem;text-overflow:ellipsis;padding-left:1px;text-align:center;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.gpt-query pre code,.gpt-response pre code,.hint-btn-text{width:100%}.gpt-query pre code,.gpt-response pre code{margin-top:.5rem;margin-bottom:.75rem;min-height:20px;-webkit-user-select:text;-moz-user-select:text;user-select:text;overflow:hidden;white-space:pre-wrap;border-radius:5px;background-color:var(--background-primary-alt);padding-left:.25rem;padding-right:.25rem;--tw-shadow:0px 2px 4px 0px #000c;--tw-shadow-colored:0px 2px 4px 0px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.gpt-response-margin-delete{margin:0}.gpt-response-button-div{margin-right:-14px;margin-bottom:-13px}.gpt-img-logo{height:4rem;padding-bottom:.5rem;opacity:.8}p.gpt-response-margin-delete code{display:inline;white-space:pre-line;border-radius:5px;background-color:var(--background-modifier-active-hover);padding-left:.25rem;padding-right:.25rem}.gpt-user-image{margin-top:5px;height:1.5rem;width:1.5rem;border-radius:50%}.hint-title-note{font-size:.75rem;line-height:1rem;font-weight:400;color:var(--text-muted)}.gpt-rel-wrap{flex-wrap:wrap}.gpt-hint-col{border-radius:5px}.gpt-hint-row{padding-top:7px}.gpt-send-active{color:var(--interactive-accent)}.gpt-send-unactive{--tw-text-opacity:1;color:rgb(128 128 128/var(--tw-text-opacity))}.discovery-div{margin-left:.25rem;justify-content:flex-end;white-space:nowrap}.discovery-div,.discovery-div-inner{display:flex;flex-wrap:nowrap;align-items:center;overflow:hidden}.discovery-title{color:var(--text-muted)}.discovery-break{padding-left:.5rem}.discovery-checkbox{margin-left:13px!important;margin-right:0!important;margin-top:22px!important}.discovery-seperator{margin-left:26px;margin-right:0;margin-top:1rem}.discovery-div-parent{position:sticky;height:0;width:0}.context-row{display:flex;width:100%;flex-direction:row;justify-content:space-between}.context-col{display:flex;height:100%;flex-direction:column}.context-parent{margin-top:.875rem;display:flex;max-height:600px;min-height:600px;width:100%;flex-direction:row;overflow:hidden}.context-preview{margin-top:-9px;overflow:hidden;overflow-x:scroll;overflow-y:scroll;padding:0 .5rem .5rem;color:var(--text-muted)}.context-list-container::-webkit-scrollbar,.context-preview::-webkit-scrollbar{display:none}.context-preview-title{margin:0;font-size:1.25rem;line-height:1.75rem;color:var(--text-muted)}.context-preview-title-parent{margin-bottom:.625rem;border-bottom-width:1px;border-bottom-color:var(--text-faint);padding:.25rem;border-bottom-style:solid}.context-list-container{margin-right:.25rem;max-height:592px;min-width:40%;max-width:40%;overflow:hidden;overflow-y:scroll;color:var(--text-muted)}.context-preview-container{margin-top:22px;margin-right:5px;margin-bottom:.5rem;max-height:570px;min-height:570px;min-width:60%;max-width:60%;border-radius:.5rem;padding:.5rem;font-size:smaller;--tw-shadow:0px 2px 4px 0px #000c;--tw-shadow-colored:0px 2px 4px 0px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}#parentFileUL,ul{list-style-type:none!important}#parentFileUL{margin:0;width:-webkit-fill-available;padding:0}.caret{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;font-weight:300;color:var(--text-accent)}.caret:before{margin-right:3px;display:inline-block;color:var(--text-muted);opacity:.9;--tw-content:"\25B6";content:var(--tw-content)}.caret:hover{color:var(--text-accent-hover)}.caret-down:before{--tw-rotate:90deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.nested{margin-left:-30px;display:none}.active{display:block}.context-list-div{display:flex;flex-direction:row;justify-content:space-between;white-space:pre}.context-list-checkbox{margin-left:.25rem!important;margin-top:3px!important;border-width:.5px!important;border-style:dashed!important;border-color:var(--checkbox-border-color)!important}.context-list-checkbox:hover{cursor:pointer!important;border-width:1px!important;border-style:solid!important;border-color:var(--text-accent-hover)!important}.context-title{margin:-1px 0 -1.5rem;padding:0;font-size:x-large;font-weight:500;color:var(--text-normal)}.context-list-div span:hover{cursor:pointer;color:var(--text-accent-hover)}.context-list-span{display:inline-block;max-width:170px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:100}.context-background{position:absolute;z-index:2;height:1.25rem;width:206px;overflow:hidden;background-color:var(--modal-background)}.context-root{position:absolute;z-index:3;font-weight:200}.context-root span{font-weight:500}.context-hide{padding-top:18px}.context-list-item{padding-top:1px;padding-bottom:1px}.context-display-width{width:inherit}.context-shadow{--tw-shadow:0px 2px 4px 0px #000c;--tw-shadow-colored:0px 2px 4px 0px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.context-preview-default{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.enrich-btn-row{display:flex;flex-direction:row;justify-content:space-between;padding-left:12rem;padding-right:12rem}.enrich-img{margin-bottom:30px;display:flex;flex-direction:row;justify-content:center}.enrich-confirm-btn,.enrich-deny-btn{cursor:pointer}.search-div{position:sticky;top:30px;left:0;z-index:9999;margin-bottom:3.5rem}.loading-bar{z-index:9999;margin-top:0;display:flex;height:5px;border-radius:5px;background-color:var(--interactive-accent)}.loading-bar:after{top:0;left:0;display:block;height:100%;width:0;content:"";transition:width 2s ease}.ask-row{display:flex;flex-direction:row;border-radius:.25rem}.ask-col{display:flex;flex-direction:column}.ask-input{width:100%;word-wrap:break-word;word-break:break-all}.ask-send-svg{margin-top:1px;margin-right:.5rem}.ask-selection{margin-top:0;margin-bottom:.5rem;max-height:300px;overflow-y:scroll;white-space:pre-wrap;border-radius:.25rem;padding:.5rem;--tw-shadow:0px 4px 8px 0px #000c;--tw-shadow-colored:0px 4px 8px 0px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow);color:var(--text-muted);word-wrap:break-word;width:-webkit-fill-available}.ask-modal-title{margin:0}.ask-input-row{margin-top:.5rem;max-height:150px;min-height:25px;border-radius:5px;padding-top:.5rem;padding-left:1rem;--tw-shadow:0px 4px 8px 0px #000c;--tw-shadow-colored:0px 4px 8px 0px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.ask-col-input{flex-grow:1;overflow-y:scroll;padding-top:1.5px}.ask-col-input::-webkit-scrollbar,.ask-selection::-webkit-scrollbar{display:none}.row{flex-direction:row}.col,.row{display:flex}.col{flex-direction:column}.width-full{width:100%}.width-max{min-width:100%;max-width:100%}.v-align-center{align-items:center}.h-align-center{justify-content:center}.annotation-form::-webkit-scrollbar,.annotation-text-body::-webkit-scrollbar{display:none}.annotation-form{display:flex;max-height:550px;width:100%;max-width:550px;flex-direction:column;overflow-y:scroll}.annotation-body{padding:.75rem}.annotation-add-body,.annotation-body{display:flex;border-radius:.5rem;border-width:1.5px;border-style:solid;border-color:var(--background-secondary-alt);background-color:var(--background-secondary)}.annotation-add-body{padding:.25rem}.annotation-text-body{margin-bottom:1rem;cursor:text;resize:none;overflow:hidden;overflow-y:scroll;text-align:start}.annotation-add-text-body,.annotation-text-body{display:block;border-style:none;background-color:initial;overflow-wrap:break-word}.annotation-add-text-body{cursor:pointer;text-align:center;font-weight:500}.annotation-text-body[contenteditable]:empty:before{--tw-text-opacity:1;color:rgb(128 128 128/var(--tw-text-opacity));--tw-content:"Add a description or a comment...";content:var(--tw-content)}.annotation-text-height-max{max-height:100px}.annotation-text-height-min{min-height:-moz-fit-content;min-height:fit-content}.annotation-metadata{align-items:center;justify-content:space-between;font-size:.75rem;line-height:1rem;font-weight:500;--tw-text-opacity:1;color:rgb(128 128 128/var(--tw-text-opacity))}.annotation-metadata-left{display:flex;align-items:center}.annotation-metadata-left svg{margin-right:.25rem;height:.75rem;width:auto}.annotation-metadata-left-btn{margin-left:.5rem;display:flex;--tw-scale-x:1.1;--tw-scale-y:1.1;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));cursor:pointer}.annotation-delete svg{color:#ff4343}.annotation-seperator{margin-left:1rem}.annotation-seperator div{height:1rem;border-color:var(--background-secondary-alt);border-left-style:solid;border-left-width:1.5px}.annotation-action-row{display:flex;flex-direction:row}@keyframes enterAnimation{0%{opacity:0}to{opacity:1}}@keyframes exitAnimation{0%{opacity:1}to{opacity:0}}.hidden-in{animation:enterAnimation .3s ease forwards}.hidden-out{animation:exitAnimation .3s ease backwards}.actions-hidden{opacity:0}.filter-grow-animation{opacity:0;animation:growFromLeft .25s forwards}@keyframes growFromLeft{to{opacity:100%}}.hover\:text-\[var\(--text-accent-hover\)\]:hover{color:var(--text-accent-hover)}.hover\:text-red-600:hover{--tw-text-opacity:1;color:rgb(220 38 38/var(--tw-text-opacity))} \ No newline at end of file