@ynput/ayon-frontend-shared 0.2.6 → 0.2.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/DetailsPanel.cjs.js +4 -0
- package/dist/DetailsPanel.cjs.js.map +1 -1
- package/dist/DetailsPanel.es.js +4 -0
- package/dist/DetailsPanel.es.js.map +1 -1
- package/dist/ProjectTreeTable.cjs.js +11 -0
- package/dist/ProjectTreeTable.cjs.js.map +1 -1
- package/dist/ProjectTreeTable.es.js +12 -1
- package/dist/ProjectTreeTable.es.js.map +1 -1
- package/dist/_virtual/index.cjs10.js +5 -3
- package/dist/_virtual/index.cjs10.js.map +1 -1
- package/dist/_virtual/index.cjs4.js +4 -4
- package/dist/_virtual/index.cjs5.js +5 -3
- package/dist/_virtual/index.cjs5.js.map +1 -1
- package/dist/_virtual/index.cjs6.js +3 -5
- package/dist/_virtual/index.cjs6.js.map +1 -1
- package/dist/_virtual/index.cjs7.js +3 -5
- package/dist/_virtual/index.cjs7.js.map +1 -1
- package/dist/_virtual/index.cjs8.js +4 -4
- package/dist/_virtual/index.cjs9.js +4 -4
- package/dist/_virtual/index.es10.js +5 -2
- package/dist/_virtual/index.es10.js.map +1 -1
- package/dist/_virtual/index.es4.js +4 -4
- package/dist/_virtual/index.es5.js +5 -2
- package/dist/_virtual/index.es5.js.map +1 -1
- package/dist/_virtual/index.es6.js +2 -5
- package/dist/_virtual/index.es6.js.map +1 -1
- package/dist/_virtual/index.es7.js +2 -5
- package/dist/_virtual/index.es7.js.map +1 -1
- package/dist/_virtual/index.es8.js +4 -4
- package/dist/_virtual/index.es9.js +4 -4
- package/dist/api.cjs.js +5 -0
- package/dist/api.cjs.js.map +1 -1
- package/dist/api.es.js +6 -1
- package/dist/api.es.js.map +1 -1
- package/dist/context.cjs.js +6 -0
- package/dist/context.cjs.js.map +1 -1
- package/dist/context.es.js +6 -0
- package/dist/context.es.js.map +1 -1
- package/dist/hooks.cjs.js +2 -0
- package/dist/hooks.cjs.js.map +1 -1
- package/dist/hooks.es.js +3 -1
- package/dist/hooks.es.js.map +1 -1
- package/dist/index.cjs.js +4 -0
- package/dist/index.cjs.js.map +1 -1
- package/dist/index.es.js +4 -0
- package/dist/index.es.js.map +1 -1
- package/dist/node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.cjs.js +1 -1
- package/dist/node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.cjs.js.map +1 -1
- package/dist/node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.es.js +1 -1
- package/dist/node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.es.js.map +1 -1
- package/dist/node_modules/@reduxjs/toolkit/dist/query/rtk-query.modern.cjs.js +12 -12
- package/dist/node_modules/@reduxjs/toolkit/dist/query/rtk-query.modern.cjs.js.map +1 -1
- package/dist/node_modules/@reduxjs/toolkit/dist/query/rtk-query.modern.es.js +12 -12
- package/dist/node_modules/@reduxjs/toolkit/dist/query/rtk-query.modern.es.js.map +1 -1
- package/dist/node_modules/decode-named-character-reference/index.dom.cjs.js +7 -3
- package/dist/node_modules/decode-named-character-reference/index.dom.cjs.js.map +1 -1
- package/dist/node_modules/decode-named-character-reference/index.dom.es.js +7 -3
- package/dist/node_modules/decode-named-character-reference/index.dom.es.js.map +1 -1
- package/dist/node_modules/graphql/language/visitor.cjs.js +1 -4
- package/dist/node_modules/graphql/language/visitor.cjs.js.map +1 -1
- package/dist/node_modules/graphql/language/visitor.es.js +1 -4
- package/dist/node_modules/graphql/language/visitor.es.js.map +1 -1
- package/dist/node_modules/match-sorter/dist/match-sorter.esm.cjs.js +18 -12
- package/dist/node_modules/match-sorter/dist/match-sorter.esm.cjs.js.map +1 -1
- package/dist/node_modules/match-sorter/dist/match-sorter.esm.es.js +18 -12
- package/dist/node_modules/match-sorter/dist/match-sorter.esm.es.js.map +1 -1
- package/dist/node_modules/parse-entities/lib/index.cjs.js +26 -24
- package/dist/node_modules/parse-entities/lib/index.cjs.js.map +1 -1
- package/dist/node_modules/parse-entities/lib/index.es.js +26 -24
- package/dist/node_modules/parse-entities/lib/index.es.js.map +1 -1
- package/dist/node_modules/parse-numeric-range/index.cjs.js +1 -1
- package/dist/node_modules/parse-numeric-range/index.es.js +1 -1
- package/dist/node_modules/react-intersection-observer/{index.cjs.js → dist/index.cjs.js} +4 -10
- package/dist/node_modules/react-intersection-observer/dist/index.cjs.js.map +1 -0
- package/dist/node_modules/react-intersection-observer/{index.es.js → dist/index.es.js} +4 -10
- package/dist/node_modules/react-intersection-observer/dist/index.es.js.map +1 -0
- package/dist/node_modules/refractor/lang/abap.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/abap.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/abnf.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/abnf.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/actionscript.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/actionscript.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/ada.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/ada.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/agda.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/agda.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/al.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/al.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/antlr4.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/antlr4.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/apacheconf.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/apacheconf.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/apex.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/apex.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/apl.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/apl.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/applescript.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/applescript.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/aql.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/aql.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/arduino.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/arduino.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/arff.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/arff.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/armasm.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/armasm.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/arturo.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/arturo.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/asciidoc.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/asciidoc.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/asm6502.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/asm6502.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/asmatmel.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/asmatmel.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/aspnet.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/aspnet.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/autohotkey.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/autohotkey.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/autoit.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/autoit.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/avisynth.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/avisynth.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/avro-idl.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/avro-idl.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/awk.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/awk.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/bash.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/bash.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/basic.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/basic.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/batch.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/batch.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/bbcode.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/bbcode.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/bbj.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/bbj.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/bicep.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/bicep.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/birb.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/birb.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/bison.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/bison.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/bnf.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/bnf.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/bqn.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/bqn.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/brainfuck.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/brainfuck.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/brightscript.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/brightscript.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/bro.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/bro.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/bsl.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/bsl.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/c.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/c.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/cfscript.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/cfscript.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/chaiscript.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/chaiscript.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/cil.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/cil.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/cilkc.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/cilkc.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/cilkcpp.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/cilkcpp.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/clike.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/clike.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/clojure.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/clojure.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/cmake.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/cmake.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/cobol.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/cobol.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/coffeescript.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/coffeescript.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/concurnas.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/concurnas.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/cooklang.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/cooklang.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/coq.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/coq.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/cpp.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/cpp.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/crystal.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/crystal.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/csharp.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/csharp.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/cshtml.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/cshtml.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/csp.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/csp.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/css-extras.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/css-extras.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/css.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/css.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/csv.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/csv.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/cue.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/cue.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/cypher.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/cypher.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/d.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/d.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/dart.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/dart.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/dataweave.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/dataweave.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/dax.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/dax.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/dhall.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/dhall.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/diff.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/diff.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/django.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/django.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/dns-zone-file.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/dns-zone-file.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/docker.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/docker.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/dot.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/dot.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/ebnf.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/ebnf.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/editorconfig.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/editorconfig.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/eiffel.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/eiffel.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/ejs.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/ejs.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/elixir.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/elixir.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/elm.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/elm.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/erb.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/erb.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/erlang.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/erlang.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/etlua.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/etlua.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/excel-formula.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/excel-formula.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/factor.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/factor.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/false.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/false.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/firestore-security-rules.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/firestore-security-rules.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/flow.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/flow.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/fortran.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/fortran.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/fsharp.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/fsharp.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/ftl.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/ftl.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/gap.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/gap.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/gcode.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/gcode.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/gdscript.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/gdscript.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/gedcom.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/gedcom.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/gettext.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/gettext.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/gherkin.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/gherkin.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/git.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/git.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/glsl.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/glsl.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/gml.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/gml.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/gn.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/gn.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/go-module.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/go-module.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/go.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/go.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/gradle.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/gradle.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/graphql.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/graphql.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/groovy.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/groovy.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/haml.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/haml.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/handlebars.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/handlebars.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/haskell.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/haskell.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/haxe.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/haxe.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/hcl.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/hcl.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/hlsl.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/hlsl.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/hoon.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/hoon.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/hpkp.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/hpkp.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/hsts.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/hsts.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/http.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/http.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/ichigojam.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/ichigojam.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/icon.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/icon.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/icu-message-format.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/icu-message-format.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/idris.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/idris.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/iecst.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/iecst.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/ignore.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/ignore.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/inform7.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/inform7.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/ini.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/ini.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/io.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/io.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/j.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/j.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/java.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/java.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/javadoc.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/javadoc.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/javadoclike.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/javadoclike.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/javascript.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/javascript.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/javastacktrace.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/javastacktrace.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/jexl.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/jexl.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/jolie.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/jolie.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/jq.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/jq.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/js-extras.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/js-extras.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/js-templates.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/js-templates.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/jsdoc.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/jsdoc.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/json.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/json.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/json5.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/json5.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/jsonp.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/jsonp.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/jsstacktrace.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/jsstacktrace.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/jsx.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/jsx.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/julia.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/julia.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/keepalived.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/keepalived.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/keyman.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/keyman.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/kotlin.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/kotlin.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/kumir.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/kumir.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/kusto.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/kusto.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/latex.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/latex.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/latte.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/latte.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/less.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/less.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/lilypond.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/lilypond.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/linker-script.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/linker-script.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/liquid.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/liquid.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/lisp.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/lisp.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/livescript.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/livescript.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/llvm.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/llvm.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/log.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/log.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/lolcode.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/lolcode.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/lua.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/lua.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/magma.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/magma.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/makefile.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/makefile.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/markdown.cjs.js +6 -4
- package/dist/node_modules/refractor/lang/markdown.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/markdown.es.js +6 -4
- package/dist/node_modules/refractor/lang/markdown.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/markup-templating.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/markup-templating.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/markup.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/markup.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/mata.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/mata.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/matlab.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/matlab.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/maxscript.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/maxscript.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/mel.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/mel.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/mermaid.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/mermaid.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/metafont.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/metafont.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/mizar.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/mizar.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/mongodb.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/mongodb.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/monkey.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/monkey.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/moonscript.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/moonscript.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/n1ql.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/n1ql.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/n4js.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/n4js.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/nand2tetris-hdl.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/nand2tetris-hdl.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/naniscript.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/naniscript.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/nasm.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/nasm.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/neon.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/neon.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/nevod.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/nevod.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/nginx.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/nginx.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/nim.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/nim.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/nix.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/nix.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/nsis.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/nsis.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/objectivec.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/objectivec.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/ocaml.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/ocaml.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/odin.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/odin.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/opencl.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/opencl.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/openqasm.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/openqasm.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/oz.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/oz.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/parigp.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/parigp.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/parser.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/parser.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/pascal.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/pascal.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/pascaligo.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/pascaligo.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/pcaxis.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/pcaxis.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/peoplecode.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/peoplecode.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/perl.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/perl.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/php-extras.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/php-extras.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/php.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/php.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/phpdoc.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/phpdoc.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/plant-uml.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/plant-uml.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/plsql.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/plsql.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/powerquery.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/powerquery.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/powershell.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/powershell.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/processing.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/processing.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/prolog.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/prolog.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/promql.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/promql.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/properties.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/properties.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/protobuf.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/protobuf.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/psl.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/psl.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/pug.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/pug.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/puppet.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/puppet.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/pure.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/pure.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/purebasic.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/purebasic.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/purescript.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/purescript.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/python.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/python.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/q.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/q.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/qml.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/qml.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/qore.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/qore.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/qsharp.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/qsharp.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/r.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/r.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/racket.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/racket.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/reason.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/reason.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/regex.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/regex.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/rego.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/rego.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/renpy.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/renpy.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/rescript.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/rescript.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/rest.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/rest.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/rip.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/rip.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/roboconf.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/roboconf.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/robotframework.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/robotframework.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/ruby.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/ruby.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/rust.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/rust.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/sas.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/sas.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/sass.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/sass.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/scala.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/scala.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/scheme.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/scheme.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/scss.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/scss.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/shell-session.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/shell-session.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/smali.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/smali.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/smalltalk.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/smalltalk.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/smarty.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/smarty.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/sml.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/sml.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/solidity.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/solidity.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/solution-file.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/solution-file.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/soy.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/soy.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/sparql.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/sparql.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/splunk-spl.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/splunk-spl.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/sqf.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/sqf.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/sql.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/sql.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/squirrel.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/squirrel.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/stan.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/stan.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/stata.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/stata.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/stylus.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/stylus.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/supercollider.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/supercollider.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/swift.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/swift.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/systemd.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/systemd.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/t4-cs.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/t4-cs.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/t4-templating.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/t4-templating.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/t4-vb.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/t4-vb.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/tap.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/tap.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/tcl.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/tcl.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/textile.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/textile.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/toml.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/toml.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/tremor.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/tremor.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/tsx.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/tsx.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/tt2.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/tt2.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/turtle.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/turtle.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/twig.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/twig.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/typescript.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/typescript.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/typoscript.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/typoscript.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/unrealscript.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/unrealscript.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/uorazor.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/uorazor.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/uri.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/uri.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/v.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/v.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/vala.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/vala.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/vbnet.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/vbnet.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/velocity.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/velocity.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/verilog.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/verilog.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/vhdl.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/vhdl.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/vim.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/vim.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/visual-basic.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/visual-basic.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/warpscript.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/warpscript.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/wasm.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/wasm.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/web-idl.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/web-idl.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/wgsl.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/wgsl.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/wiki.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/wiki.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/wolfram.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/wolfram.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/wren.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/wren.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/xeora.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/xeora.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/xml-doc.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/xml-doc.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/xojo.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/xojo.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/xquery.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/xquery.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/yaml.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/yaml.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/yang.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/yang.es.js.map +1 -1
- package/dist/node_modules/refractor/lang/zig.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lang/zig.es.js.map +1 -1
- package/dist/node_modules/refractor/lib/all.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lib/all.es.js.map +1 -1
- package/dist/node_modules/refractor/lib/common.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lib/common.es.js.map +1 -1
- package/dist/node_modules/refractor/lib/core.cjs.js +10 -10
- package/dist/node_modules/refractor/lib/core.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lib/core.es.js +10 -10
- package/dist/node_modules/refractor/lib/core.es.js.map +1 -1
- package/dist/node_modules/refractor/lib/prism-core.cjs.js +6 -3
- package/dist/node_modules/refractor/lib/prism-core.cjs.js.map +1 -1
- package/dist/node_modules/refractor/lib/prism-core.es.js +6 -3
- package/dist/node_modules/refractor/lib/prism-core.es.js.map +1 -1
- package/dist/node_modules/rehype/node_modules/unified/lib/index.cjs.js +2 -2
- package/dist/node_modules/rehype/node_modules/unified/lib/index.es.js +2 -2
- package/dist/node_modules/rehype-parse/lib/index.cjs.js +1 -1
- package/dist/node_modules/rehype-parse/lib/index.es.js +1 -1
- package/dist/node_modules/rehype-prism-plus/dist/index.es.cjs.js +1 -1
- package/dist/node_modules/rehype-prism-plus/dist/index.es.es.js +1 -1
- package/dist/node_modules/remove-accents/index.cjs.js +1 -1
- package/dist/node_modules/remove-accents/index.es.js +1 -1
- package/dist/node_modules/vfile/lib/index.cjs.js +1 -1
- package/dist/node_modules/vfile/lib/index.es.js +1 -1
- package/dist/shared/src/api/generated/graphql.cjs.js +6 -2
- package/dist/shared/src/api/generated/graphql.cjs.js.map +1 -1
- package/dist/shared/src/api/generated/graphql.es.js +6 -2
- package/dist/shared/src/api/generated/graphql.es.js.map +1 -1
- package/dist/shared/src/api/queries/entities/transformDetailsPanelData.cjs.js +1 -0
- package/dist/shared/src/api/queries/entities/transformDetailsPanelData.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/entities/transformDetailsPanelData.es.js +1 -0
- package/dist/shared/src/api/queries/entities/transformDetailsPanelData.es.js.map +1 -1
- package/dist/shared/src/api/queries/entities/updateEntity.cjs.js +1 -0
- package/dist/shared/src/api/queries/entities/updateEntity.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/entities/updateEntity.es.js +1 -0
- package/dist/shared/src/api/queries/entities/updateEntity.es.js.map +1 -1
- package/dist/shared/src/api/queries/entityLists/getLists.cjs.js +6 -4
- package/dist/shared/src/api/queries/entityLists/getLists.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/entityLists/getLists.es.js +6 -4
- package/dist/shared/src/api/queries/entityLists/getLists.es.js.map +1 -1
- package/dist/shared/src/api/queries/entityLists/updateLists.cjs.js +65 -1
- package/dist/shared/src/api/queries/entityLists/updateLists.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/entityLists/updateLists.es.js +65 -1
- package/dist/shared/src/api/queries/entityLists/updateLists.es.js.map +1 -1
- package/dist/shared/src/api/queries/overview/updateOverview.cjs.js +1 -0
- package/dist/shared/src/api/queries/overview/updateOverview.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/overview/updateOverview.es.js +1 -0
- package/dist/shared/src/api/queries/overview/updateOverview.es.js.map +1 -1
- package/dist/shared/src/api/queries/permissions/getPermissions.cjs.js +52 -0
- package/dist/shared/src/api/queries/permissions/getPermissions.cjs.js.map +1 -0
- package/dist/shared/src/api/queries/permissions/getPermissions.es.js +52 -0
- package/dist/shared/src/api/queries/permissions/getPermissions.es.js.map +1 -0
- package/dist/shared/src/api/queries/users/getUsers.cjs.js +1 -5
- package/dist/shared/src/api/queries/users/getUsers.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/users/getUsers.es.js +1 -5
- package/dist/shared/src/api/queries/users/getUsers.es.js.map +1 -1
- package/dist/shared/src/api/queries/users/updateUsers.cjs.js +22 -14
- package/dist/shared/src/api/queries/users/updateUsers.cjs.js.map +1 -1
- package/dist/shared/src/api/queries/users/updateUsers.es.js +22 -14
- package/dist/shared/src/api/queries/users/updateUsers.es.js.map +1 -1
- package/dist/shared/src/components/DetailsDialog/DetailsDialog.cjs.js +1 -0
- package/dist/shared/src/components/DetailsDialog/DetailsDialog.cjs.js.map +1 -1
- package/dist/shared/src/components/DetailsDialog/DetailsDialog.es.js +1 -0
- package/dist/shared/src/components/DetailsDialog/DetailsDialog.es.js.map +1 -1
- package/dist/shared/src/components/DetailsPanelAttributes/DetailsPanelAttributes.cjs.js +1 -1
- package/dist/shared/src/components/DetailsPanelAttributes/DetailsPanelAttributes.es.js +1 -1
- package/dist/shared/src/components/EntityPath/SegmentProvider.cjs.js +2 -0
- package/dist/shared/src/components/EntityPath/SegmentProvider.cjs.js.map +1 -1
- package/dist/shared/src/components/EntityPath/SegmentProvider.es.js +2 -0
- package/dist/shared/src/components/EntityPath/SegmentProvider.es.js.map +1 -1
- package/dist/shared/src/components/EntityThumbnailUploader/EntityThumbnailUploader.cjs.js +4 -0
- package/dist/shared/src/components/EntityThumbnailUploader/EntityThumbnailUploader.cjs.js.map +1 -1
- package/dist/shared/src/components/EntityThumbnailUploader/EntityThumbnailUploader.es.js +4 -0
- package/dist/shared/src/components/EntityThumbnailUploader/EntityThumbnailUploader.es.js.map +1 -1
- package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.cjs.js +5 -0
- package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.cjs.js.map +1 -1
- package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.es.js +5 -0
- package/dist/shared/src/components/ProjectTableSettings/ProjectTableSettings.es.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/EditReviewableDialog.cjs.js +1 -0
- package/dist/shared/src/components/ReviewablesList/EditReviewableDialog.cjs.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/EditReviewableDialog.es.js +1 -0
- package/dist/shared/src/components/ReviewablesList/EditReviewableDialog.es.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/ReviewablesList.cjs.js +4 -0
- package/dist/shared/src/components/ReviewablesList/ReviewablesList.cjs.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/ReviewablesList.es.js +4 -0
- package/dist/shared/src/components/ReviewablesList/ReviewablesList.es.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.cjs.js +4 -0
- package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.cjs.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.es.js +4 -0
- package/dist/shared/src/components/ReviewablesList/ReviewablesUpload.es.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.cjs.js +4 -0
- package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.cjs.js.map +1 -1
- package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.es.js +4 -0
- package/dist/shared/src/components/ReviewablesList/SortableReviewableCard.es.js.map +1 -1
- package/dist/shared/src/components/SettingsPanel/SettingsPanel.cjs.js +2 -0
- package/dist/shared/src/components/SettingsPanel/SettingsPanel.cjs.js.map +1 -1
- package/dist/shared/src/components/SettingsPanel/SettingsPanel.es.js +2 -0
- package/dist/shared/src/components/SettingsPanel/SettingsPanel.es.js.map +1 -1
- package/dist/shared/src/components/Thumbnail/StackedThumbnails.cjs.js +6 -0
- package/dist/shared/src/components/Thumbnail/StackedThumbnails.cjs.js.map +1 -1
- package/dist/shared/src/components/Thumbnail/StackedThumbnails.es.js +6 -0
- package/dist/shared/src/components/Thumbnail/StackedThumbnails.es.js.map +1 -1
- package/dist/shared/src/components/Thumbnail/Thumbnail.styled.cjs.js +2 -7
- package/dist/shared/src/components/Thumbnail/Thumbnail.styled.cjs.js.map +1 -1
- package/dist/shared/src/components/Thumbnail/Thumbnail.styled.es.js +2 -7
- package/dist/shared/src/components/Thumbnail/Thumbnail.styled.es.js.map +1 -1
- package/dist/shared/src/components/Watchers/Watchers.cjs.js +1 -0
- package/dist/shared/src/components/Watchers/Watchers.cjs.js.map +1 -1
- package/dist/shared/src/components/Watchers/Watchers.es.js +1 -0
- package/dist/shared/src/components/Watchers/Watchers.es.js.map +1 -1
- package/dist/shared/src/containers/Actions/ActionConfigDialog.cjs.js +4 -0
- package/dist/shared/src/containers/Actions/ActionConfigDialog.cjs.js.map +1 -1
- package/dist/shared/src/containers/Actions/ActionConfigDialog.es.js +4 -0
- package/dist/shared/src/containers/Actions/ActionConfigDialog.es.js.map +1 -1
- package/dist/shared/src/containers/Actions/ActionIcon.cjs.js +1 -1
- package/dist/shared/src/containers/Actions/ActionIcon.cjs.js.map +1 -1
- package/dist/shared/src/containers/Actions/ActionIcon.es.js +1 -1
- package/dist/shared/src/containers/Actions/ActionIcon.es.js.map +1 -1
- package/dist/shared/src/containers/Actions/Actions.cjs.js +18 -10
- package/dist/shared/src/containers/Actions/Actions.cjs.js.map +1 -1
- package/dist/shared/src/containers/Actions/Actions.es.js +18 -10
- package/dist/shared/src/containers/Actions/Actions.es.js.map +1 -1
- package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.cjs.js +2 -2
- package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.cjs.js.map +1 -1
- package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.es.js +2 -2
- package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.es.js.map +1 -1
- package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.styled.cjs.js +4 -0
- package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.styled.cjs.js.map +1 -1
- package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.styled.es.js +4 -0
- package/dist/shared/src/containers/Actions/ActionsDropdown/ActionsDropdown.styled.es.js.map +1 -1
- package/dist/shared/src/containers/Actions/InteractiveActionDialog.cjs.js +4 -0
- package/dist/shared/src/containers/Actions/InteractiveActionDialog.cjs.js.map +1 -1
- package/dist/shared/src/containers/Actions/InteractiveActionDialog.es.js +4 -0
- package/dist/shared/src/containers/Actions/InteractiveActionDialog.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanel.cjs.js +4 -0
- package/dist/shared/src/containers/DetailsPanel/DetailsPanel.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanel.es.js +4 -0
- package/dist/shared/src/containers/DetailsPanel/DetailsPanel.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.cjs.js +4 -0
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.es.js +4 -0
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFiles/DetailsPanelFiles.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.cjs.js +4 -0
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.es.js +4 -0
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelFloating/DetailsPanelFloating.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.cjs.js +13 -3
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.es.js +13 -3
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelHeader/DetailsPanelHeader.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelSlideOut/DetailsPanelSlideOut.cjs.js +3 -0
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelSlideOut/DetailsPanelSlideOut.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelSlideOut/DetailsPanelSlideOut.es.js +3 -0
- package/dist/shared/src/containers/DetailsPanel/DetailsPanelSlideOut/DetailsPanelSlideOut.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/FeedWrapper.cjs.js +2 -0
- package/dist/shared/src/containers/DetailsPanel/FeedWrapper.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/FeedWrapper.es.js +2 -0
- package/dist/shared/src/containers/DetailsPanel/FeedWrapper.es.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/hooks/useGetEntityPath.cjs.js +1 -0
- package/dist/shared/src/containers/DetailsPanel/hooks/useGetEntityPath.cjs.js.map +1 -1
- package/dist/shared/src/containers/DetailsPanel/hooks/useGetEntityPath.es.js +1 -0
- package/dist/shared/src/containers/DetailsPanel/hooks/useGetEntityPath.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/Feed.cjs.js +3 -1
- package/dist/shared/src/containers/Feed/Feed.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/Feed.es.js +3 -1
- package/dist/shared/src/containers/Feed/Feed.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityVersions/ActivityVersions.cjs.js +2 -0
- package/dist/shared/src/containers/Feed/components/ActivityVersions/ActivityVersions.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/ActivityVersions/ActivityVersions.es.js +2 -0
- package/dist/shared/src/containers/Feed/components/ActivityVersions/ActivityVersions.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useAnnotationsSync.cjs.js +2 -0
- package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useAnnotationsSync.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useAnnotationsSync.es.js +2 -0
- package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useAnnotationsSync.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useMentionLink.cjs.js +2 -0
- package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useMentionLink.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useMentionLink.es.js +2 -0
- package/dist/shared/src/containers/Feed/components/CommentInput/hooks/useMentionLink.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/Tooltips/EntityTooltip/EntityTooltip.cjs.js +2 -0
- package/dist/shared/src/containers/Feed/components/Tooltips/EntityTooltip/EntityTooltip.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/components/Tooltips/EntityTooltip/EntityTooltip.es.js +2 -0
- package/dist/shared/src/containers/Feed/components/Tooltips/EntityTooltip/EntityTooltip.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/context/FeedContext.cjs.js +3 -0
- package/dist/shared/src/containers/Feed/context/FeedContext.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/context/FeedContext.es.js +3 -0
- package/dist/shared/src/containers/Feed/context/FeedContext.es.js.map +1 -1
- package/dist/shared/src/containers/Feed/hooks/useGetFeedActivitiesData.cjs.js +1 -0
- package/dist/shared/src/containers/Feed/hooks/useGetFeedActivitiesData.cjs.js.map +1 -1
- package/dist/shared/src/containers/Feed/hooks/useGetFeedActivitiesData.es.js +1 -0
- package/dist/shared/src/containers/Feed/hooks/useGetFeedActivitiesData.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.cjs.js +278 -54
- package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.es.js +280 -56
- package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.styled.cjs.js +38 -4
- package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.styled.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.styled.es.js +38 -4
- package/dist/shared/src/containers/ProjectTreeTable/ProjectTreeTable.styled.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.cjs.js +49 -21
- package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.es.js +49 -21
- package/dist/shared/src/containers/ProjectTreeTable/buildTreeTableColumns.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/components/RowDragHandleCellContent.cjs.js +33 -0
- package/dist/shared/src/containers/ProjectTreeTable/components/RowDragHandleCellContent.cjs.js.map +1 -0
- package/dist/shared/src/containers/ProjectTreeTable/components/RowDragHandleCellContent.es.js +34 -0
- package/dist/shared/src/containers/ProjectTreeTable/components/RowDragHandleCellContent.es.js.map +1 -0
- package/dist/shared/src/containers/ProjectTreeTable/context/ColumnSettingsContext.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ColumnSettingsContext.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectDataContext.cjs.js +116 -0
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectDataContext.cjs.js.map +1 -0
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectDataContext.es.js +116 -0
- package/dist/shared/src/containers/ProjectTreeTable/context/ProjectDataContext.es.js.map +1 -0
- package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsContext.cjs.js +2 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsContext.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsContext.es.js +2 -1
- package/dist/shared/src/containers/ProjectTreeTable/context/SelectionCellsContext.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useAttributesList.cjs.js +84 -0
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useAttributesList.cjs.js.map +1 -0
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useAttributesList.es.js +85 -0
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useAttributesList.es.js.map +1 -0
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useOverviewTable.cjs.js +0 -36
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useOverviewTable.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useOverviewTable.es.js +0 -36
- package/dist/shared/src/containers/ProjectTreeTable/hooks/useOverviewTable.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/utils/clientFilterToQueryFilter.cjs.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/utils/clientFilterToQueryFilter.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/utils/clientFilterToQueryFilter.es.js +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/utils/clientFilterToQueryFilter.es.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/ThumbnailWidget.cjs.js +3 -2
- package/dist/shared/src/containers/ProjectTreeTable/widgets/ThumbnailWidget.cjs.js.map +1 -1
- package/dist/shared/src/containers/ProjectTreeTable/widgets/ThumbnailWidget.es.js +3 -2
- package/dist/shared/src/containers/ProjectTreeTable/widgets/ThumbnailWidget.es.js.map +1 -1
- package/dist/shared/src/containers/RepresentationsList/RepresentationsList.cjs.js +4 -0
- package/dist/shared/src/containers/RepresentationsList/RepresentationsList.cjs.js.map +1 -1
- package/dist/shared/src/containers/RepresentationsList/RepresentationsList.es.js +4 -0
- package/dist/shared/src/containers/RepresentationsList/RepresentationsList.es.js.map +1 -1
- package/dist/shared/src/context/AddonContext.cjs.js +18 -0
- package/dist/shared/src/context/AddonContext.cjs.js.map +1 -0
- package/dist/shared/src/context/AddonContext.es.js +18 -0
- package/dist/shared/src/context/AddonContext.es.js.map +1 -0
- package/dist/shared/src/context/AddonProjectContext.cjs.js +91 -0
- package/dist/shared/src/context/AddonProjectContext.cjs.js.map +1 -0
- package/dist/shared/src/context/AddonProjectContext.es.js +91 -0
- package/dist/shared/src/context/AddonProjectContext.es.js.map +1 -0
- package/dist/shared/src/context/DetailsPanelContext.cjs.js +3 -1
- package/dist/shared/src/context/DetailsPanelContext.cjs.js.map +1 -1
- package/dist/shared/src/context/DetailsPanelContext.es.js +3 -1
- package/dist/shared/src/context/DetailsPanelContext.es.js.map +1 -1
- package/dist/shared/src/context/RemoteModulesContext.cjs.js +1 -0
- package/dist/shared/src/context/RemoteModulesContext.cjs.js.map +1 -1
- package/dist/shared/src/context/RemoteModulesContext.es.js +1 -0
- package/dist/shared/src/context/RemoteModulesContext.es.js.map +1 -1
- package/dist/shared/src/hooks/useActionTriggers.cjs.js +7 -6
- package/dist/shared/src/hooks/useActionTriggers.cjs.js.map +1 -1
- package/dist/shared/src/hooks/useActionTriggers.es.js +7 -6
- package/dist/shared/src/hooks/useActionTriggers.es.js.map +1 -1
- package/dist/shared/src/hooks/useEntityUpdate.cjs.js +3 -0
- package/dist/shared/src/hooks/useEntityUpdate.cjs.js.map +1 -1
- package/dist/shared/src/hooks/useEntityUpdate.es.js +3 -0
- package/dist/shared/src/hooks/useEntityUpdate.es.js.map +1 -1
- package/dist/shared/src/hooks/useLoadModule.cjs.js +19 -4
- package/dist/shared/src/hooks/useLoadModule.cjs.js.map +1 -1
- package/dist/shared/src/hooks/useLoadModule.es.js +19 -4
- package/dist/shared/src/hooks/useLoadModule.es.js.map +1 -1
- package/dist/shared/src/hooks/useScopedStatuses.cjs.js +1 -0
- package/dist/shared/src/hooks/useScopedStatuses.cjs.js.map +1 -1
- package/dist/shared/src/hooks/useScopedStatuses.es.js +1 -0
- package/dist/shared/src/hooks/useScopedStatuses.es.js.map +1 -1
- package/dist/shared/src/hooks/useUserProjectConfig.cjs.js +108 -0
- package/dist/shared/src/hooks/useUserProjectConfig.cjs.js.map +1 -0
- package/dist/shared/src/hooks/useUserProjectConfig.es.js +108 -0
- package/dist/shared/src/hooks/useUserProjectConfig.es.js.map +1 -0
- package/dist/types/SimpleTable/SimpleTable.d.ts +9 -2
- package/dist/types/SimpleTable/SimpleTableRowTemplate.d.ts +7 -0
- package/dist/types/SimpleTable/context/SimpleTableContext.d.ts +7 -5
- package/dist/types/api/generated/graphql.d.ts +11 -4
- package/dist/types/api/queries/entityLists/getLists.d.ts +2 -1
- package/dist/types/api/queries/entityLists/types.d.ts +1 -0
- package/dist/types/api/queries/index.d.ts +1 -0
- package/dist/types/api/queries/permissions/getPermissions.d.ts +294 -0
- package/dist/types/api/queries/permissions/index.d.ts +1 -0
- package/dist/types/api/queries/users/getUsers.d.ts +0 -1
- package/dist/types/containers/Actions/Actions.d.ts +5 -3
- package/dist/types/containers/ProjectTreeTable/ProjectTreeTable.d.ts +14 -6
- package/dist/types/containers/ProjectTreeTable/components/RowDragHandleCellContent.d.ts +5 -0
- package/dist/types/containers/ProjectTreeTable/context/ColumnSettingsContext.d.ts +1 -1
- package/dist/types/containers/ProjectTreeTable/context/ProjectDataContext.d.ts +22 -0
- package/dist/types/containers/ProjectTreeTable/context/index.d.ts +1 -0
- package/dist/types/containers/ProjectTreeTable/hooks/useAttributesList.d.ts +12 -0
- package/dist/types/containers/ProjectTreeTable/index.d.ts +1 -0
- package/dist/types/containers/ProjectTreeTable/widgets/ThumbnailWidget.d.ts +1 -1
- package/dist/types/context/AddonContext.d.ts +18 -0
- package/dist/types/context/AddonProjectContext.d.ts +28 -0
- package/dist/types/context/DetailsPanelContext.d.ts +7 -2
- package/dist/types/context/index.d.ts +2 -0
- package/dist/types/hooks/index.d.ts +1 -0
- package/dist/types/hooks/useActionTriggers.d.ts +6 -1
- package/dist/types/hooks/useLoadModule.d.ts +1 -0
- package/dist/types/hooks/useUserProjectConfig.d.ts +13 -0
- package/package.json +1 -1
- package/dist/node_modules/react-intersection-observer/index.cjs.js.map +0 -1
- package/dist/node_modules/react-intersection-observer/index.es.js.map +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ReviewablesUpload.cjs.js","sources":["../../../../../src/components/ReviewablesList/ReviewablesUpload.tsx"],"sourcesContent":["import axios, { AxiosProgressEvent, AxiosResponse } from 'axios'\nimport { toast } from 'react-toastify'\nimport { FC, useState, DragEvent, ChangeEvent } from 'react'\nimport clsx from 'clsx'\n\nimport { Icon } from '@ynput/ayon-react-components'\n\nimport api, { reviewablesQueries } from '@shared/api'\nimport type { UploadReviewableApiResponse } from '@shared/api'\n\n// components\nimport { ReviewableProgress, ReviewableProgressCard } from '@shared/components'\nimport * as Styled from './ReviewablesUpload.styled'\nimport { useDetailsPanelContext } from '@shared/context'\n\nexport interface ReviewableUploadProps {\n projectName: string | null\n versionId: string\n productId: string | null\n variant?: 'normal' | 'large'\n onUpload?: () => void\n children?: any\n}\n\nexport const ReviewableUpload: FC<ReviewableUploadProps> = ({\n projectName,\n versionId,\n productId,\n onUpload,\n children,\n variant = 'normal',\n}) => {\n const { viewer, dispatch } = useDetailsPanelContext()\n\n const taskId = viewer?.taskId\n const folderId = viewer?.folderId\n\n // are we dragging a file over?\n const [isDraggingFile, setIsDraggingFile] = useState(false)\n\n const [uploading, setUploads] = useState<{ [key: string]: ReviewableProgress[] }>({})\n\n const handleRemoveUpload = (name: string) => {\n setUploads((uploads) => ({\n ...uploads,\n [versionId]: uploads[versionId]?.filter((upload) => upload.name !== name) || [],\n }))\n }\n\n const handleFileUpload = async (files: FileList) => {\n const uploadingFiles = Array.from(files).map((file) => ({\n name: file.name,\n size: file.size,\n progress: 0,\n }))\n\n const newUploadsForVersion = [...(uploading[versionId] || []), ...uploadingFiles]\n\n setUploads({ ...uploading, [versionId]: newUploadsForVersion })\n\n const successHandler = (file: File) => (response: AxiosResponse) => {\n // Handle successful upload\n console.log(`Upload successful for ${file.name}`)\n // patch the new data into the reviewables cache\n const data = response.data as UploadReviewableApiResponse\n\n if (!projectName) return\n\n dispatch(\n // @ts-ignore\n reviewablesQueries.util.updateQueryData(\n 'getReviewablesForVersion',\n { projectName, versionId },\n (draft) => {\n if (!draft.reviewables) {\n draft.reviewables = []\n }\n // @ts-ignore\n draft.reviewables.push(data)\n },\n ),\n )\n\n // also invalidate the viewer cache\n productId && dispatch(api.util.invalidateTags([{ type: 'viewer', id: productId }]))\n dispatch(api.util.invalidateTags([{ type: 'viewer', id: versionId }]))\n dispatch(api.util.invalidateTags([{ type: 'viewer', id: folderId }]))\n dispatch(api.util.invalidateTags([{ type: 'viewer', id: taskId }]))\n // remove the file from the list\n handleRemoveUpload(file.name)\n }\n\n const errorHandler = (file: File) => (error: any) => {\n console.error(`Upload failed for ${file.name}: ${error}`)\n toast.error(`Failed to upload file: ${file.name}`)\n // add error to the file\n setUploads((uploads) => {\n // current uploads for versionId\n const currentUploads = uploads[versionId] || []\n const updatedUploads = currentUploads.map((upload) => {\n if (upload.name !== file.name) return upload\n return {\n ...upload,\n error: error.response.data.detail || error.message,\n }\n })\n\n // update state\n return {\n ...uploads,\n [versionId]: updatedUploads,\n }\n })\n }\n\n const progressHandler = (file: File) => {\n return (progressEvent: AxiosProgressEvent) =>\n setUploads((uploads) => {\n // current uploads for versionId\n const currentUploads = uploads[versionId] || []\n const updatedUploads = currentUploads.map((upload) => {\n if (upload.name !== file.name) return upload\n return {\n ...upload,\n progress: progressEvent.total\n ? Math.round((progressEvent.loaded / progressEvent.total) * 100)\n : 0,\n }\n })\n\n // update state\n return {\n ...uploads,\n [versionId]: updatedUploads,\n }\n })\n }\n\n try {\n // upload the files\n for (const file of files) {\n const autoLabel = file.name.split('.').slice(0, -1).join('.')\n\n const url = `/api/projects/${projectName}/versions/${versionId}/reviewables?label=${autoLabel}`\n const headers = { 'content-type': file.type, 'x-file-name': file.name }\n axios\n .post(url, file, { headers, onUploadProgress: progressHandler(file) })\n .then(successHandler(file))\n .catch(errorHandler(file))\n }\n // Callback after successful uploads\n onUpload && onUpload()\n } catch (error) {\n // something went wrong with everything, EEEEK!\n console.error(error)\n toast.error('Failed to upload file/s')\n }\n }\n\n const handleInputChange = (event: ChangeEvent<HTMLInputElement>) => {\n const files = event.target.files\n\n if (files) {\n handleFileUpload(files)\n }\n }\n\n // when the user drops a file\n const handleFileDrop = (event: DragEvent<HTMLDivElement>) => {\n event.preventDefault()\n setIsDraggingFile(false)\n\n const files = event.dataTransfer.files\n\n if (files) {\n handleFileUpload(files)\n }\n }\n const variantStyles =\n variant === 'large' ? { minWidth: '360px', maxWidth: '480px', alignSelf: 'center' } : {}\n\n return (\n <>\n {!isDraggingFile && (\n <Styled.ReviewablesList\n onDragEnter={() => setIsDraggingFile(true)}\n className={clsx(variant)}\n >\n <>\n {children}\n {/* uploading items */}\n {uploading[versionId]?.map((file) => (\n <ReviewableProgressCard\n key={file.name}\n {...file}\n type={'upload'}\n onRemove={() => handleRemoveUpload(file.name)}\n />\n ))}\n\n {/* upload button */}\n <Styled.Upload id=\"upload\" className={clsx('upload', variant)} style={variantStyles}>\n <span>Drop or click to upload</span>\n <input type=\"file\" multiple onChange={handleInputChange} />\n </Styled.Upload>\n </>\n </Styled.ReviewablesList>\n )}\n\n {isDraggingFile && (\n <Styled.Dropzone\n onDragOver={(e) => e.preventDefault()}\n onDragLeave={() => setIsDraggingFile(false)}\n onDrop={handleFileDrop}\n >\n <Icon icon=\"upload\" />\n <span>Upload reviewable</span>\n </Styled.Dropzone>\n )}\n </>\n )\n}\n\nexport default ReviewableUpload\n"],"names":["useDetailsPanelContext","useState","_a","reviewablesQueries","api","toast","jsxs","Fragment","jsx","Styled.ReviewablesList","ReviewableProgressCard","Styled.Upload","Styled.Dropzone","Icon"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"ReviewablesUpload.cjs.js","sources":["../../../../../src/components/ReviewablesList/ReviewablesUpload.tsx"],"sourcesContent":["import axios, { AxiosProgressEvent, AxiosResponse } from 'axios'\nimport { toast } from 'react-toastify'\nimport { FC, useState, DragEvent, ChangeEvent } from 'react'\nimport clsx from 'clsx'\n\nimport { Icon } from '@ynput/ayon-react-components'\n\nimport api, { reviewablesQueries } from '@shared/api'\nimport type { UploadReviewableApiResponse } from '@shared/api'\n\n// components\nimport { ReviewableProgress, ReviewableProgressCard } from '@shared/components'\nimport * as Styled from './ReviewablesUpload.styled'\nimport { useDetailsPanelContext } from '@shared/context'\n\nexport interface ReviewableUploadProps {\n projectName: string | null\n versionId: string\n productId: string | null\n variant?: 'normal' | 'large'\n onUpload?: () => void\n children?: any\n}\n\nexport const ReviewableUpload: FC<ReviewableUploadProps> = ({\n projectName,\n versionId,\n productId,\n onUpload,\n children,\n variant = 'normal',\n}) => {\n const { viewer, dispatch } = useDetailsPanelContext()\n\n const taskId = viewer?.taskId\n const folderId = viewer?.folderId\n\n // are we dragging a file over?\n const [isDraggingFile, setIsDraggingFile] = useState(false)\n\n const [uploading, setUploads] = useState<{ [key: string]: ReviewableProgress[] }>({})\n\n const handleRemoveUpload = (name: string) => {\n setUploads((uploads) => ({\n ...uploads,\n [versionId]: uploads[versionId]?.filter((upload) => upload.name !== name) || [],\n }))\n }\n\n const handleFileUpload = async (files: FileList) => {\n const uploadingFiles = Array.from(files).map((file) => ({\n name: file.name,\n size: file.size,\n progress: 0,\n }))\n\n const newUploadsForVersion = [...(uploading[versionId] || []), ...uploadingFiles]\n\n setUploads({ ...uploading, [versionId]: newUploadsForVersion })\n\n const successHandler = (file: File) => (response: AxiosResponse) => {\n // Handle successful upload\n console.log(`Upload successful for ${file.name}`)\n // patch the new data into the reviewables cache\n const data = response.data as UploadReviewableApiResponse\n\n if (!projectName) return\n\n dispatch(\n // @ts-ignore\n reviewablesQueries.util.updateQueryData(\n 'getReviewablesForVersion',\n { projectName, versionId },\n (draft) => {\n if (!draft.reviewables) {\n draft.reviewables = []\n }\n // @ts-ignore\n draft.reviewables.push(data)\n },\n ),\n )\n\n // also invalidate the viewer cache\n productId && dispatch(api.util.invalidateTags([{ type: 'viewer', id: productId }]))\n dispatch(api.util.invalidateTags([{ type: 'viewer', id: versionId }]))\n dispatch(api.util.invalidateTags([{ type: 'viewer', id: folderId }]))\n dispatch(api.util.invalidateTags([{ type: 'viewer', id: taskId }]))\n // remove the file from the list\n handleRemoveUpload(file.name)\n }\n\n const errorHandler = (file: File) => (error: any) => {\n console.error(`Upload failed for ${file.name}: ${error}`)\n toast.error(`Failed to upload file: ${file.name}`)\n // add error to the file\n setUploads((uploads) => {\n // current uploads for versionId\n const currentUploads = uploads[versionId] || []\n const updatedUploads = currentUploads.map((upload) => {\n if (upload.name !== file.name) return upload\n return {\n ...upload,\n error: error.response.data.detail || error.message,\n }\n })\n\n // update state\n return {\n ...uploads,\n [versionId]: updatedUploads,\n }\n })\n }\n\n const progressHandler = (file: File) => {\n return (progressEvent: AxiosProgressEvent) =>\n setUploads((uploads) => {\n // current uploads for versionId\n const currentUploads = uploads[versionId] || []\n const updatedUploads = currentUploads.map((upload) => {\n if (upload.name !== file.name) return upload\n return {\n ...upload,\n progress: progressEvent.total\n ? Math.round((progressEvent.loaded / progressEvent.total) * 100)\n : 0,\n }\n })\n\n // update state\n return {\n ...uploads,\n [versionId]: updatedUploads,\n }\n })\n }\n\n try {\n // upload the files\n for (const file of files) {\n const autoLabel = file.name.split('.').slice(0, -1).join('.')\n\n const url = `/api/projects/${projectName}/versions/${versionId}/reviewables?label=${autoLabel}`\n const headers = { 'content-type': file.type, 'x-file-name': file.name }\n axios\n .post(url, file, { headers, onUploadProgress: progressHandler(file) })\n .then(successHandler(file))\n .catch(errorHandler(file))\n }\n // Callback after successful uploads\n onUpload && onUpload()\n } catch (error) {\n // something went wrong with everything, EEEEK!\n console.error(error)\n toast.error('Failed to upload file/s')\n }\n }\n\n const handleInputChange = (event: ChangeEvent<HTMLInputElement>) => {\n const files = event.target.files\n\n if (files) {\n handleFileUpload(files)\n }\n }\n\n // when the user drops a file\n const handleFileDrop = (event: DragEvent<HTMLDivElement>) => {\n event.preventDefault()\n setIsDraggingFile(false)\n\n const files = event.dataTransfer.files\n\n if (files) {\n handleFileUpload(files)\n }\n }\n const variantStyles =\n variant === 'large' ? { minWidth: '360px', maxWidth: '480px', alignSelf: 'center' } : {}\n\n return (\n <>\n {!isDraggingFile && (\n <Styled.ReviewablesList\n onDragEnter={() => setIsDraggingFile(true)}\n className={clsx(variant)}\n >\n <>\n {children}\n {/* uploading items */}\n {uploading[versionId]?.map((file) => (\n <ReviewableProgressCard\n key={file.name}\n {...file}\n type={'upload'}\n onRemove={() => handleRemoveUpload(file.name)}\n />\n ))}\n\n {/* upload button */}\n <Styled.Upload id=\"upload\" className={clsx('upload', variant)} style={variantStyles}>\n <span>Drop or click to upload</span>\n <input type=\"file\" multiple onChange={handleInputChange} />\n </Styled.Upload>\n </>\n </Styled.ReviewablesList>\n )}\n\n {isDraggingFile && (\n <Styled.Dropzone\n onDragOver={(e) => e.preventDefault()}\n onDragLeave={() => setIsDraggingFile(false)}\n onDrop={handleFileDrop}\n >\n <Icon icon=\"upload\" />\n <span>Upload reviewable</span>\n </Styled.Dropzone>\n )}\n </>\n )\n}\n\nexport default ReviewableUpload\n"],"names":["useDetailsPanelContext","useState","_a","reviewablesQueries","api","toast","jsxs","Fragment","jsx","Styled.ReviewablesList","ReviewableProgressCard","Styled.Upload","Styled.Dropzone","Icon"],"mappings":"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"}
|
|
@@ -68,6 +68,7 @@ import "../../api/queries/userDashboard/getUserDashboard.es.js";
|
|
|
68
68
|
import "../../api/queries/users/getUsers.es.js";
|
|
69
69
|
import "../../api/queries/users/updateUsers.es.js";
|
|
70
70
|
import "../../api/queries/watchers/getWatchers.es.js";
|
|
71
|
+
import "../../api/queries/permissions/getPermissions.es.js";
|
|
71
72
|
import "../ThumbnailSimple/ThumbnailSimple.es.js";
|
|
72
73
|
import "../EmptyPlaceholder/EmptyPlaceholder.es.js";
|
|
73
74
|
import "../EmptyPlaceholder/EmptyPlaceholderFlex.styled.es.js";
|
|
@@ -86,6 +87,8 @@ import "../../context/SettingsPanelContext.es.js";
|
|
|
86
87
|
import "../../context/pip/PiPProvider.es.js";
|
|
87
88
|
import "react-dom";
|
|
88
89
|
import "../../context/pip/PiPWrapper.es.js";
|
|
90
|
+
import "../../context/AddonProjectContext.es.js";
|
|
91
|
+
import "../../context/AddonContext.es.js";
|
|
89
92
|
import "../ReviewableCard/ReviewableCard.es.js";
|
|
90
93
|
import { ReviewableProgressCard } from "../ReviewableProgressCard/ReviewableProgressCard.es.js";
|
|
91
94
|
import "../FileThumbnail/FileThumbnail.es.js";
|
|
@@ -128,6 +131,7 @@ import "../../containers/ProjectTreeTable/context/ColumnSettingsContext.es.js";
|
|
|
128
131
|
import "../../containers/ProjectTreeTable/context/CellEditingContext.es.js";
|
|
129
132
|
import "../../containers/ProjectTreeTable/context/ClipboardContext.es.js";
|
|
130
133
|
import "../../containers/ProjectTreeTable/context/ProjectTableSelectionContext.es.js";
|
|
134
|
+
import "../../containers/ProjectTreeTable/context/ProjectDataContext.es.js";
|
|
131
135
|
import "@tanstack/react-table";
|
|
132
136
|
import "../../containers/ProjectTreeTable/widgets/CollapsedWidget.es.js";
|
|
133
137
|
import "../../containers/ProjectTreeTable/widgets/DateWidget.es.js";
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ReviewablesUpload.es.js","sources":["../../../../../src/components/ReviewablesList/ReviewablesUpload.tsx"],"sourcesContent":["import axios, { AxiosProgressEvent, AxiosResponse } from 'axios'\nimport { toast } from 'react-toastify'\nimport { FC, useState, DragEvent, ChangeEvent } from 'react'\nimport clsx from 'clsx'\n\nimport { Icon } from '@ynput/ayon-react-components'\n\nimport api, { reviewablesQueries } from '@shared/api'\nimport type { UploadReviewableApiResponse } from '@shared/api'\n\n// components\nimport { ReviewableProgress, ReviewableProgressCard } from '@shared/components'\nimport * as Styled from './ReviewablesUpload.styled'\nimport { useDetailsPanelContext } from '@shared/context'\n\nexport interface ReviewableUploadProps {\n projectName: string | null\n versionId: string\n productId: string | null\n variant?: 'normal' | 'large'\n onUpload?: () => void\n children?: any\n}\n\nexport const ReviewableUpload: FC<ReviewableUploadProps> = ({\n projectName,\n versionId,\n productId,\n onUpload,\n children,\n variant = 'normal',\n}) => {\n const { viewer, dispatch } = useDetailsPanelContext()\n\n const taskId = viewer?.taskId\n const folderId = viewer?.folderId\n\n // are we dragging a file over?\n const [isDraggingFile, setIsDraggingFile] = useState(false)\n\n const [uploading, setUploads] = useState<{ [key: string]: ReviewableProgress[] }>({})\n\n const handleRemoveUpload = (name: string) => {\n setUploads((uploads) => ({\n ...uploads,\n [versionId]: uploads[versionId]?.filter((upload) => upload.name !== name) || [],\n }))\n }\n\n const handleFileUpload = async (files: FileList) => {\n const uploadingFiles = Array.from(files).map((file) => ({\n name: file.name,\n size: file.size,\n progress: 0,\n }))\n\n const newUploadsForVersion = [...(uploading[versionId] || []), ...uploadingFiles]\n\n setUploads({ ...uploading, [versionId]: newUploadsForVersion })\n\n const successHandler = (file: File) => (response: AxiosResponse) => {\n // Handle successful upload\n console.log(`Upload successful for ${file.name}`)\n // patch the new data into the reviewables cache\n const data = response.data as UploadReviewableApiResponse\n\n if (!projectName) return\n\n dispatch(\n // @ts-ignore\n reviewablesQueries.util.updateQueryData(\n 'getReviewablesForVersion',\n { projectName, versionId },\n (draft) => {\n if (!draft.reviewables) {\n draft.reviewables = []\n }\n // @ts-ignore\n draft.reviewables.push(data)\n },\n ),\n )\n\n // also invalidate the viewer cache\n productId && dispatch(api.util.invalidateTags([{ type: 'viewer', id: productId }]))\n dispatch(api.util.invalidateTags([{ type: 'viewer', id: versionId }]))\n dispatch(api.util.invalidateTags([{ type: 'viewer', id: folderId }]))\n dispatch(api.util.invalidateTags([{ type: 'viewer', id: taskId }]))\n // remove the file from the list\n handleRemoveUpload(file.name)\n }\n\n const errorHandler = (file: File) => (error: any) => {\n console.error(`Upload failed for ${file.name}: ${error}`)\n toast.error(`Failed to upload file: ${file.name}`)\n // add error to the file\n setUploads((uploads) => {\n // current uploads for versionId\n const currentUploads = uploads[versionId] || []\n const updatedUploads = currentUploads.map((upload) => {\n if (upload.name !== file.name) return upload\n return {\n ...upload,\n error: error.response.data.detail || error.message,\n }\n })\n\n // update state\n return {\n ...uploads,\n [versionId]: updatedUploads,\n }\n })\n }\n\n const progressHandler = (file: File) => {\n return (progressEvent: AxiosProgressEvent) =>\n setUploads((uploads) => {\n // current uploads for versionId\n const currentUploads = uploads[versionId] || []\n const updatedUploads = currentUploads.map((upload) => {\n if (upload.name !== file.name) return upload\n return {\n ...upload,\n progress: progressEvent.total\n ? Math.round((progressEvent.loaded / progressEvent.total) * 100)\n : 0,\n }\n })\n\n // update state\n return {\n ...uploads,\n [versionId]: updatedUploads,\n }\n })\n }\n\n try {\n // upload the files\n for (const file of files) {\n const autoLabel = file.name.split('.').slice(0, -1).join('.')\n\n const url = `/api/projects/${projectName}/versions/${versionId}/reviewables?label=${autoLabel}`\n const headers = { 'content-type': file.type, 'x-file-name': file.name }\n axios\n .post(url, file, { headers, onUploadProgress: progressHandler(file) })\n .then(successHandler(file))\n .catch(errorHandler(file))\n }\n // Callback after successful uploads\n onUpload && onUpload()\n } catch (error) {\n // something went wrong with everything, EEEEK!\n console.error(error)\n toast.error('Failed to upload file/s')\n }\n }\n\n const handleInputChange = (event: ChangeEvent<HTMLInputElement>) => {\n const files = event.target.files\n\n if (files) {\n handleFileUpload(files)\n }\n }\n\n // when the user drops a file\n const handleFileDrop = (event: DragEvent<HTMLDivElement>) => {\n event.preventDefault()\n setIsDraggingFile(false)\n\n const files = event.dataTransfer.files\n\n if (files) {\n handleFileUpload(files)\n }\n }\n const variantStyles =\n variant === 'large' ? { minWidth: '360px', maxWidth: '480px', alignSelf: 'center' } : {}\n\n return (\n <>\n {!isDraggingFile && (\n <Styled.ReviewablesList\n onDragEnter={() => setIsDraggingFile(true)}\n className={clsx(variant)}\n >\n <>\n {children}\n {/* uploading items */}\n {uploading[versionId]?.map((file) => (\n <ReviewableProgressCard\n key={file.name}\n {...file}\n type={'upload'}\n onRemove={() => handleRemoveUpload(file.name)}\n />\n ))}\n\n {/* upload button */}\n <Styled.Upload id=\"upload\" className={clsx('upload', variant)} style={variantStyles}>\n <span>Drop or click to upload</span>\n <input type=\"file\" multiple onChange={handleInputChange} />\n </Styled.Upload>\n </>\n </Styled.ReviewablesList>\n )}\n\n {isDraggingFile && (\n <Styled.Dropzone\n onDragOver={(e) => e.preventDefault()}\n onDragLeave={() => setIsDraggingFile(false)}\n onDrop={handleFileDrop}\n >\n <Icon icon=\"upload\" />\n <span>Upload reviewable</span>\n </Styled.Dropzone>\n )}\n </>\n )\n}\n\nexport default ReviewableUpload\n"],"names":["_a","reviewablesQueries","jsxs","Fragment","jsx","Styled.ReviewablesList","Styled.Upload","Styled.Dropzone"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"ReviewablesUpload.es.js","sources":["../../../../../src/components/ReviewablesList/ReviewablesUpload.tsx"],"sourcesContent":["import axios, { AxiosProgressEvent, AxiosResponse } from 'axios'\nimport { toast } from 'react-toastify'\nimport { FC, useState, DragEvent, ChangeEvent } from 'react'\nimport clsx from 'clsx'\n\nimport { Icon } from '@ynput/ayon-react-components'\n\nimport api, { reviewablesQueries } from '@shared/api'\nimport type { UploadReviewableApiResponse } from '@shared/api'\n\n// components\nimport { ReviewableProgress, ReviewableProgressCard } from '@shared/components'\nimport * as Styled from './ReviewablesUpload.styled'\nimport { useDetailsPanelContext } from '@shared/context'\n\nexport interface ReviewableUploadProps {\n projectName: string | null\n versionId: string\n productId: string | null\n variant?: 'normal' | 'large'\n onUpload?: () => void\n children?: any\n}\n\nexport const ReviewableUpload: FC<ReviewableUploadProps> = ({\n projectName,\n versionId,\n productId,\n onUpload,\n children,\n variant = 'normal',\n}) => {\n const { viewer, dispatch } = useDetailsPanelContext()\n\n const taskId = viewer?.taskId\n const folderId = viewer?.folderId\n\n // are we dragging a file over?\n const [isDraggingFile, setIsDraggingFile] = useState(false)\n\n const [uploading, setUploads] = useState<{ [key: string]: ReviewableProgress[] }>({})\n\n const handleRemoveUpload = (name: string) => {\n setUploads((uploads) => ({\n ...uploads,\n [versionId]: uploads[versionId]?.filter((upload) => upload.name !== name) || [],\n }))\n }\n\n const handleFileUpload = async (files: FileList) => {\n const uploadingFiles = Array.from(files).map((file) => ({\n name: file.name,\n size: file.size,\n progress: 0,\n }))\n\n const newUploadsForVersion = [...(uploading[versionId] || []), ...uploadingFiles]\n\n setUploads({ ...uploading, [versionId]: newUploadsForVersion })\n\n const successHandler = (file: File) => (response: AxiosResponse) => {\n // Handle successful upload\n console.log(`Upload successful for ${file.name}`)\n // patch the new data into the reviewables cache\n const data = response.data as UploadReviewableApiResponse\n\n if (!projectName) return\n\n dispatch(\n // @ts-ignore\n reviewablesQueries.util.updateQueryData(\n 'getReviewablesForVersion',\n { projectName, versionId },\n (draft) => {\n if (!draft.reviewables) {\n draft.reviewables = []\n }\n // @ts-ignore\n draft.reviewables.push(data)\n },\n ),\n )\n\n // also invalidate the viewer cache\n productId && dispatch(api.util.invalidateTags([{ type: 'viewer', id: productId }]))\n dispatch(api.util.invalidateTags([{ type: 'viewer', id: versionId }]))\n dispatch(api.util.invalidateTags([{ type: 'viewer', id: folderId }]))\n dispatch(api.util.invalidateTags([{ type: 'viewer', id: taskId }]))\n // remove the file from the list\n handleRemoveUpload(file.name)\n }\n\n const errorHandler = (file: File) => (error: any) => {\n console.error(`Upload failed for ${file.name}: ${error}`)\n toast.error(`Failed to upload file: ${file.name}`)\n // add error to the file\n setUploads((uploads) => {\n // current uploads for versionId\n const currentUploads = uploads[versionId] || []\n const updatedUploads = currentUploads.map((upload) => {\n if (upload.name !== file.name) return upload\n return {\n ...upload,\n error: error.response.data.detail || error.message,\n }\n })\n\n // update state\n return {\n ...uploads,\n [versionId]: updatedUploads,\n }\n })\n }\n\n const progressHandler = (file: File) => {\n return (progressEvent: AxiosProgressEvent) =>\n setUploads((uploads) => {\n // current uploads for versionId\n const currentUploads = uploads[versionId] || []\n const updatedUploads = currentUploads.map((upload) => {\n if (upload.name !== file.name) return upload\n return {\n ...upload,\n progress: progressEvent.total\n ? Math.round((progressEvent.loaded / progressEvent.total) * 100)\n : 0,\n }\n })\n\n // update state\n return {\n ...uploads,\n [versionId]: updatedUploads,\n }\n })\n }\n\n try {\n // upload the files\n for (const file of files) {\n const autoLabel = file.name.split('.').slice(0, -1).join('.')\n\n const url = `/api/projects/${projectName}/versions/${versionId}/reviewables?label=${autoLabel}`\n const headers = { 'content-type': file.type, 'x-file-name': file.name }\n axios\n .post(url, file, { headers, onUploadProgress: progressHandler(file) })\n .then(successHandler(file))\n .catch(errorHandler(file))\n }\n // Callback after successful uploads\n onUpload && onUpload()\n } catch (error) {\n // something went wrong with everything, EEEEK!\n console.error(error)\n toast.error('Failed to upload file/s')\n }\n }\n\n const handleInputChange = (event: ChangeEvent<HTMLInputElement>) => {\n const files = event.target.files\n\n if (files) {\n handleFileUpload(files)\n }\n }\n\n // when the user drops a file\n const handleFileDrop = (event: DragEvent<HTMLDivElement>) => {\n event.preventDefault()\n setIsDraggingFile(false)\n\n const files = event.dataTransfer.files\n\n if (files) {\n handleFileUpload(files)\n }\n }\n const variantStyles =\n variant === 'large' ? { minWidth: '360px', maxWidth: '480px', alignSelf: 'center' } : {}\n\n return (\n <>\n {!isDraggingFile && (\n <Styled.ReviewablesList\n onDragEnter={() => setIsDraggingFile(true)}\n className={clsx(variant)}\n >\n <>\n {children}\n {/* uploading items */}\n {uploading[versionId]?.map((file) => (\n <ReviewableProgressCard\n key={file.name}\n {...file}\n type={'upload'}\n onRemove={() => handleRemoveUpload(file.name)}\n />\n ))}\n\n {/* upload button */}\n <Styled.Upload id=\"upload\" className={clsx('upload', variant)} style={variantStyles}>\n <span>Drop or click to upload</span>\n <input type=\"file\" multiple onChange={handleInputChange} />\n </Styled.Upload>\n </>\n </Styled.ReviewablesList>\n )}\n\n {isDraggingFile && (\n <Styled.Dropzone\n onDragOver={(e) => e.preventDefault()}\n onDragLeave={() => setIsDraggingFile(false)}\n onDrop={handleFileDrop}\n >\n <Icon icon=\"upload\" />\n <span>Upload reviewable</span>\n </Styled.Dropzone>\n )}\n </>\n )\n}\n\nexport default ReviewableUpload\n"],"names":["_a","reviewablesQueries","jsxs","Fragment","jsx","Styled.ReviewablesList","Styled.Upload","Styled.Dropzone"],"mappings":"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"}
|
|
@@ -72,6 +72,7 @@ require("../../api/queries/userDashboard/getUserDashboard.cjs.js");
|
|
|
72
72
|
require("../../api/queries/users/getUsers.cjs.js");
|
|
73
73
|
require("../../api/queries/users/updateUsers.cjs.js");
|
|
74
74
|
require("../../api/queries/watchers/getWatchers.cjs.js");
|
|
75
|
+
require("../../api/queries/permissions/getPermissions.cjs.js");
|
|
75
76
|
require("react");
|
|
76
77
|
require("@dnd-kit/core");
|
|
77
78
|
require("./ReviewablesList.styled.cjs.js");
|
|
@@ -88,6 +89,8 @@ require("../../context/SettingsPanelContext.cjs.js");
|
|
|
88
89
|
require("../../context/pip/PiPProvider.cjs.js");
|
|
89
90
|
require("react-dom");
|
|
90
91
|
require("../../context/pip/PiPWrapper.cjs.js");
|
|
92
|
+
require("../../context/AddonProjectContext.cjs.js");
|
|
93
|
+
require("../../context/AddonContext.cjs.js");
|
|
91
94
|
const ReviewableCard = require("../ReviewableCard/ReviewableCard.cjs.js");
|
|
92
95
|
require("../ReviewableProgressCard/ReviewableProgressCard.styled.cjs.js");
|
|
93
96
|
require("../FileThumbnail/FileThumbnail.cjs.js");
|
|
@@ -130,6 +133,7 @@ require("../../containers/ProjectTreeTable/context/ColumnSettingsContext.cjs.js"
|
|
|
130
133
|
require("../../containers/ProjectTreeTable/context/CellEditingContext.cjs.js");
|
|
131
134
|
require("../../containers/ProjectTreeTable/context/ClipboardContext.cjs.js");
|
|
132
135
|
require("../../containers/ProjectTreeTable/context/ProjectTableSelectionContext.cjs.js");
|
|
136
|
+
require("../../containers/ProjectTreeTable/context/ProjectDataContext.cjs.js");
|
|
133
137
|
require("@tanstack/react-table");
|
|
134
138
|
require("../../containers/ProjectTreeTable/widgets/CollapsedWidget.cjs.js");
|
|
135
139
|
require("../../containers/ProjectTreeTable/widgets/DateWidget.cjs.js");
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SortableReviewableCard.cjs.js","sources":["../../../../../src/components/ReviewablesList/SortableReviewableCard.tsx"],"sourcesContent":["import { FC } from 'react'\nimport { useSortable } from '@dnd-kit/sortable'\nimport { CSS } from '@dnd-kit/utilities'\nimport { ReviewableCardProps, ReviewableCard } from '@shared/components'\n\ntype SortableReviewableCardProps = ReviewableCardProps\n\nconst SortableReviewableCard: FC<SortableReviewableCardProps> = ({ ...props }) => {\n const { attributes, listeners, setNodeRef, transform, transition, isDragging } = useSortable({\n id: props.fileId,\n animateLayoutChanges: () => false,\n })\n\n const style = {\n transform: CSS.Transform.toString(transform),\n transition,\n }\n\n return (\n <div ref={setNodeRef} style={style}>\n <ReviewableCard\n isDropPlaceholder={isDragging}\n dragProps={{ ...attributes, ...listeners }}\n disabled={props.sortingDisabled}\n {...props}\n />\n </div>\n )\n}\n\nexport default SortableReviewableCard\n"],"names":["useSortable","CSS","jsx","ReviewableCard"],"mappings":"
|
|
1
|
+
{"version":3,"file":"SortableReviewableCard.cjs.js","sources":["../../../../../src/components/ReviewablesList/SortableReviewableCard.tsx"],"sourcesContent":["import { FC } from 'react'\nimport { useSortable } from '@dnd-kit/sortable'\nimport { CSS } from '@dnd-kit/utilities'\nimport { ReviewableCardProps, ReviewableCard } from '@shared/components'\n\ntype SortableReviewableCardProps = ReviewableCardProps\n\nconst SortableReviewableCard: FC<SortableReviewableCardProps> = ({ ...props }) => {\n const { attributes, listeners, setNodeRef, transform, transition, isDragging } = useSortable({\n id: props.fileId,\n animateLayoutChanges: () => false,\n })\n\n const style = {\n transform: CSS.Transform.toString(transform),\n transition,\n }\n\n return (\n <div ref={setNodeRef} style={style}>\n <ReviewableCard\n isDropPlaceholder={isDragging}\n dragProps={{ ...attributes, ...listeners }}\n disabled={props.sortingDisabled}\n {...props}\n />\n </div>\n )\n}\n\nexport default SortableReviewableCard\n"],"names":["useSortable","CSS","jsx","ReviewableCard"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAOA,MAAM,yBAA0D,CAAC,EAAE,GAAG,YAAY;AAC1E,QAAA,EAAE,YAAY,WAAW,YAAY,WAAW,YAAY,eAAeA,qBAAY;AAAA,IAC3F,IAAI,MAAM;AAAA,IACV,sBAAsB,MAAM;AAAA,EAAA,CAC7B;AAED,QAAM,QAAQ;AAAA,IACZ,WAAWC,cAAA,IAAI,UAAU,SAAS,SAAS;AAAA,IAC3C;AAAA,EACF;AAEA,SACGC,2BAAAA,kBAAAA,IAAA,OAAA,EAAI,KAAK,YAAY,OACpB,UAAAA,2BAAA,kBAAA;AAAA,IAACC,eAAA;AAAA,IAAA;AAAA,MACC,mBAAmB;AAAA,MACnB,WAAW,EAAE,GAAG,YAAY,GAAG,UAAU;AAAA,MACzC,UAAU,MAAM;AAAA,MACf,GAAG;AAAA,IAAA;AAAA,EAAA,GAER;AAEJ;;"}
|
|
@@ -71,6 +71,7 @@ import "../../api/queries/userDashboard/getUserDashboard.es.js";
|
|
|
71
71
|
import "../../api/queries/users/getUsers.es.js";
|
|
72
72
|
import "../../api/queries/users/updateUsers.es.js";
|
|
73
73
|
import "../../api/queries/watchers/getWatchers.es.js";
|
|
74
|
+
import "../../api/queries/permissions/getPermissions.es.js";
|
|
74
75
|
import "react";
|
|
75
76
|
import "@dnd-kit/core";
|
|
76
77
|
import "./ReviewablesList.styled.es.js";
|
|
@@ -87,6 +88,8 @@ import "../../context/SettingsPanelContext.es.js";
|
|
|
87
88
|
import "../../context/pip/PiPProvider.es.js";
|
|
88
89
|
import "react-dom";
|
|
89
90
|
import "../../context/pip/PiPWrapper.es.js";
|
|
91
|
+
import "../../context/AddonProjectContext.es.js";
|
|
92
|
+
import "../../context/AddonContext.es.js";
|
|
90
93
|
import { ReviewableCard } from "../ReviewableCard/ReviewableCard.es.js";
|
|
91
94
|
import "../ReviewableProgressCard/ReviewableProgressCard.styled.es.js";
|
|
92
95
|
import "../FileThumbnail/FileThumbnail.es.js";
|
|
@@ -129,6 +132,7 @@ import "../../containers/ProjectTreeTable/context/ColumnSettingsContext.es.js";
|
|
|
129
132
|
import "../../containers/ProjectTreeTable/context/CellEditingContext.es.js";
|
|
130
133
|
import "../../containers/ProjectTreeTable/context/ClipboardContext.es.js";
|
|
131
134
|
import "../../containers/ProjectTreeTable/context/ProjectTableSelectionContext.es.js";
|
|
135
|
+
import "../../containers/ProjectTreeTable/context/ProjectDataContext.es.js";
|
|
132
136
|
import "@tanstack/react-table";
|
|
133
137
|
import "../../containers/ProjectTreeTable/widgets/CollapsedWidget.es.js";
|
|
134
138
|
import "../../containers/ProjectTreeTable/widgets/DateWidget.es.js";
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SortableReviewableCard.es.js","sources":["../../../../../src/components/ReviewablesList/SortableReviewableCard.tsx"],"sourcesContent":["import { FC } from 'react'\nimport { useSortable } from '@dnd-kit/sortable'\nimport { CSS } from '@dnd-kit/utilities'\nimport { ReviewableCardProps, ReviewableCard } from '@shared/components'\n\ntype SortableReviewableCardProps = ReviewableCardProps\n\nconst SortableReviewableCard: FC<SortableReviewableCardProps> = ({ ...props }) => {\n const { attributes, listeners, setNodeRef, transform, transition, isDragging } = useSortable({\n id: props.fileId,\n animateLayoutChanges: () => false,\n })\n\n const style = {\n transform: CSS.Transform.toString(transform),\n transition,\n }\n\n return (\n <div ref={setNodeRef} style={style}>\n <ReviewableCard\n isDropPlaceholder={isDragging}\n dragProps={{ ...attributes, ...listeners }}\n disabled={props.sortingDisabled}\n {...props}\n />\n </div>\n )\n}\n\nexport default SortableReviewableCard\n"],"names":["jsx"],"mappings":"
|
|
1
|
+
{"version":3,"file":"SortableReviewableCard.es.js","sources":["../../../../../src/components/ReviewablesList/SortableReviewableCard.tsx"],"sourcesContent":["import { FC } from 'react'\nimport { useSortable } from '@dnd-kit/sortable'\nimport { CSS } from '@dnd-kit/utilities'\nimport { ReviewableCardProps, ReviewableCard } from '@shared/components'\n\ntype SortableReviewableCardProps = ReviewableCardProps\n\nconst SortableReviewableCard: FC<SortableReviewableCardProps> = ({ ...props }) => {\n const { attributes, listeners, setNodeRef, transform, transition, isDragging } = useSortable({\n id: props.fileId,\n animateLayoutChanges: () => false,\n })\n\n const style = {\n transform: CSS.Transform.toString(transform),\n transition,\n }\n\n return (\n <div ref={setNodeRef} style={style}>\n <ReviewableCard\n isDropPlaceholder={isDragging}\n dragProps={{ ...attributes, ...listeners }}\n disabled={props.sortingDisabled}\n {...props}\n />\n </div>\n )\n}\n\nexport default SortableReviewableCard\n"],"names":["jsx"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAOA,MAAM,yBAA0D,CAAC,EAAE,GAAG,YAAY;AAC1E,QAAA,EAAE,YAAY,WAAW,YAAY,WAAW,YAAY,eAAe,YAAY;AAAA,IAC3F,IAAI,MAAM;AAAA,IACV,sBAAsB,MAAM;AAAA,EAAA,CAC7B;AAED,QAAM,QAAQ;AAAA,IACZ,WAAW,IAAI,UAAU,SAAS,SAAS;AAAA,IAC3C;AAAA,EACF;AAEA,SACGA,kCAAAA,IAAA,OAAA,EAAI,KAAK,YAAY,OACpB,UAAAA,kCAAA;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,mBAAmB;AAAA,MACnB,WAAW,EAAE,GAAG,YAAY,GAAG,UAAU;AAAA,MACzC,UAAU,MAAM;AAAA,MACf,GAAG;AAAA,IAAA;AAAA,EAAA,GAER;AAEJ;"}
|
|
@@ -10,6 +10,8 @@ const SettingsPanelContext = require("../../context/SettingsPanelContext.cjs.js"
|
|
|
10
10
|
require("../../context/pip/PiPProvider.cjs.js");
|
|
11
11
|
require("react-dom");
|
|
12
12
|
require("../../context/pip/PiPWrapper.cjs.js");
|
|
13
|
+
require("../../context/AddonProjectContext.cjs.js");
|
|
14
|
+
require("../../context/AddonContext.cjs.js");
|
|
13
15
|
const SidePanel = styled.div`
|
|
14
16
|
height: 100%;
|
|
15
17
|
overflow: hidden;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SettingsPanel.cjs.js","sources":["../../../../../src/components/SettingsPanel/SettingsPanel.tsx"],"sourcesContent":["import { Button, Icon } from '@ynput/ayon-react-components'\nimport { FC, ReactNode } from 'react'\nimport styled from 'styled-components'\nimport { SettingField, useSettingsPanel } from '@shared/context'\n\n// Side panel styled components\nconst SidePanel = styled.div<{ open: boolean }>`\n height: 100%;\n overflow: hidden;\n background-color: var(--md-sys-color-surface-container-low);\n border-radius: 4px;\n z-index: 10;\n display: flex;\n flex-direction: column;\n`\n\nconst PanelHeader = styled.div`\n display: flex;\n align-items: center;\n gap: var(--base-gap-small);\n height: 34px;\n padding: 0px 4px;\n border-bottom: 1px solid var(--md-sys-color-outline-variant);\n\n h3 {\n margin-left: 4px;\n padding: 0;\n }\n`\n\nconst ToolButton = styled(Button)`\n padding: 4px !important;\n`\n\nconst PanelTitle = styled.h3`\n margin: 0;\n flex: 1;\n`\n\nconst PanelContent = styled.div`\n padding: 8px;\n flex: 1;\n overflow-y: auto;\n`\n\nexport const SettingOption = styled(Button)`\n width: 100%;\n justify-content: flex-start;\n margin-bottom: 8px;\n text-align: left;\n display: flex;\n gap: var(--base-gap-small);\n\n .title {\n flex: 1;\n }\n\n .preview {\n color: var(--md-sys-color-outline);\n }\n`\n\nexport interface SettingConfig {\n id: SettingField\n title: string\n component: ReactNode\n icon?: string\n preview?: string | number\n}\n\nexport interface SettingsPanelProps {\n settings: SettingConfig[]\n}\n\nexport const SettingsPanel: FC<SettingsPanelProps> = ({ settings }) => {\n const { isPanelOpen, selectedSetting, closePanel, backToMainMenu, selectSetting } =\n useSettingsPanel()\n\n const getPanelTitle = () => {\n if (!selectedSetting) return 'Settings'\n const setting = settings.find((s) => s.id === selectedSetting)\n return setting?.title || 'Settings'\n }\n\n const renderSettingContent = () => {\n if (!selectedSetting) {\n // Render main menu\n return (\n <>\n {settings.map((setting) => (\n <SettingOption\n key={setting.id}\n onClick={() => selectSetting(setting.id)}\n variant=\"text\"\n >\n {setting.icon && <Icon icon={setting.icon} />}\n <span className=\"title\">{setting.title}</span>\n {!!setting.preview?.toString() && <span className=\"preview\">{setting.preview}</span>}\n </SettingOption>\n ))}\n </>\n )\n }\n\n const setting = settings.find((s) => s.id === selectedSetting)\n return setting?.component\n }\n\n return (\n <SidePanel open={isPanelOpen}>\n <PanelHeader>\n {selectedSetting && settings.length > 1 && (\n <ToolButton variant=\"text\" icon=\"arrow_back\" onClick={backToMainMenu} />\n )}\n <PanelTitle>{getPanelTitle()}</PanelTitle>\n <ToolButton variant=\"text\" icon=\"close\" onClick={closePanel} />\n </PanelHeader>\n <PanelContent>{renderSettingContent()}</PanelContent>\n </SidePanel>\n )\n}\n"],"names":["Button","useSettingsPanel","jsx","Fragment","setting","jsxs","Icon"],"mappings":"
|
|
1
|
+
{"version":3,"file":"SettingsPanel.cjs.js","sources":["../../../../../src/components/SettingsPanel/SettingsPanel.tsx"],"sourcesContent":["import { Button, Icon } from '@ynput/ayon-react-components'\nimport { FC, ReactNode } from 'react'\nimport styled from 'styled-components'\nimport { SettingField, useSettingsPanel } from '@shared/context'\n\n// Side panel styled components\nconst SidePanel = styled.div<{ open: boolean }>`\n height: 100%;\n overflow: hidden;\n background-color: var(--md-sys-color-surface-container-low);\n border-radius: 4px;\n z-index: 10;\n display: flex;\n flex-direction: column;\n`\n\nconst PanelHeader = styled.div`\n display: flex;\n align-items: center;\n gap: var(--base-gap-small);\n height: 34px;\n padding: 0px 4px;\n border-bottom: 1px solid var(--md-sys-color-outline-variant);\n\n h3 {\n margin-left: 4px;\n padding: 0;\n }\n`\n\nconst ToolButton = styled(Button)`\n padding: 4px !important;\n`\n\nconst PanelTitle = styled.h3`\n margin: 0;\n flex: 1;\n`\n\nconst PanelContent = styled.div`\n padding: 8px;\n flex: 1;\n overflow-y: auto;\n`\n\nexport const SettingOption = styled(Button)`\n width: 100%;\n justify-content: flex-start;\n margin-bottom: 8px;\n text-align: left;\n display: flex;\n gap: var(--base-gap-small);\n\n .title {\n flex: 1;\n }\n\n .preview {\n color: var(--md-sys-color-outline);\n }\n`\n\nexport interface SettingConfig {\n id: SettingField\n title: string\n component: ReactNode\n icon?: string\n preview?: string | number\n}\n\nexport interface SettingsPanelProps {\n settings: SettingConfig[]\n}\n\nexport const SettingsPanel: FC<SettingsPanelProps> = ({ settings }) => {\n const { isPanelOpen, selectedSetting, closePanel, backToMainMenu, selectSetting } =\n useSettingsPanel()\n\n const getPanelTitle = () => {\n if (!selectedSetting) return 'Settings'\n const setting = settings.find((s) => s.id === selectedSetting)\n return setting?.title || 'Settings'\n }\n\n const renderSettingContent = () => {\n if (!selectedSetting) {\n // Render main menu\n return (\n <>\n {settings.map((setting) => (\n <SettingOption\n key={setting.id}\n onClick={() => selectSetting(setting.id)}\n variant=\"text\"\n >\n {setting.icon && <Icon icon={setting.icon} />}\n <span className=\"title\">{setting.title}</span>\n {!!setting.preview?.toString() && <span className=\"preview\">{setting.preview}</span>}\n </SettingOption>\n ))}\n </>\n )\n }\n\n const setting = settings.find((s) => s.id === selectedSetting)\n return setting?.component\n }\n\n return (\n <SidePanel open={isPanelOpen}>\n <PanelHeader>\n {selectedSetting && settings.length > 1 && (\n <ToolButton variant=\"text\" icon=\"arrow_back\" onClick={backToMainMenu} />\n )}\n <PanelTitle>{getPanelTitle()}</PanelTitle>\n <ToolButton variant=\"text\" icon=\"close\" onClick={closePanel} />\n </PanelHeader>\n <PanelContent>{renderSettingContent()}</PanelContent>\n </SidePanel>\n )\n}\n"],"names":["Button","useSettingsPanel","jsx","Fragment","setting","jsxs","Icon"],"mappings":";;;;;;;;;;;;;;AAMA,MAAM,YAAY,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAUzB,MAAM,cAAc,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAc3B,MAAM,aAAa,OAAOA,0BAAM;AAAA;AAAA;AAIhC,MAAM,aAAa,OAAO;AAAA;AAAA;AAAA;AAK1B,MAAM,eAAe,OAAO;AAAA;AAAA;AAAA;AAAA;AAMf,MAAA,gBAAgB,OAAOA,0BAAM;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AA6BnC,MAAM,gBAAwC,CAAC,EAAE,eAAe;AACrE,QAAM,EAAE,aAAa,iBAAiB,YAAY,gBAAgB,kBAChEC,sCAAiB;AAEnB,QAAM,gBAAgB,MAAM;AACtB,QAAA,CAAC,gBAAwB,QAAA;AAC7B,UAAM,UAAU,SAAS,KAAK,CAAC,MAAM,EAAE,OAAO,eAAe;AAC7D,YAAO,mCAAS,UAAS;AAAA,EAC3B;AAEA,QAAM,uBAAuB,MAAM;AACjC,QAAI,CAAC,iBAAiB;AAEpB,aAEKC,2BAAAA,kBAAAA,IAAAC,WAAAA,kBAAAA,UAAA,EAAA,UAAA,SAAS,IAAI,CAACC;;AACbC,0CAAA,kBAAA;AAAA,UAAC;AAAA,UAAA;AAAA,YAEC,SAAS,MAAM,cAAcD,SAAQ,EAAE;AAAA,YACvC,SAAQ;AAAA,YAEP,UAAA;AAAA,cAAAA,SAAQ,QAAQF,iDAACI,oBAAAA,MAAK,EAAA,MAAMF,SAAQ,MAAM;AAAA,+DAC1C,QAAK,EAAA,WAAU,SAAS,UAAAA,SAAQ,OAAM;AAAA,cACtC,CAAC,GAACA,cAAQ,YAARA,mBAAiB,eAAeF,2BAAA,kBAAA,IAAA,QAAA,EAAK,WAAU,WAAW,UAAAE,SAAQ,QAAQ,CAAA;AAAA,YAAA;AAAA,UAAA;AAAA,UANxEA,SAAQ;AAAA,QAQhB;AAAA,OAAA,GACH;AAAA,IAAA;AAIJ,UAAM,UAAU,SAAS,KAAK,CAAC,MAAM,EAAE,OAAO,eAAe;AAC7D,WAAO,mCAAS;AAAA,EAClB;AAGE,SAAAC,2BAAA,kBAAA,KAAC,WAAU,EAAA,MAAM,aACf,UAAA;AAAA,IAAAA,kDAAC,aACE,EAAA,UAAA;AAAA,MAAmB,mBAAA,SAAS,SAAS,KACnCH,2BAAA,kBAAA,IAAA,YAAA,EAAW,SAAQ,QAAO,MAAK,cAAa,SAAS,eAAgB,CAAA;AAAA,MAExEA,2BAAAA,kBAAAA,IAAC,YAAY,EAAA,UAAA,cAAgB,EAAA,CAAA;AAAA,uDAC5B,YAAW,EAAA,SAAQ,QAAO,MAAK,SAAQ,SAAS,WAAY,CAAA;AAAA,IAAA,GAC/D;AAAA,IACAA,2BAAAA,kBAAAA,IAAC,cAAc,EAAA,UAAA,qBAAA,EAAuB,CAAA;AAAA,EAAA,GACxC;AAEJ;;;"}
|
|
@@ -8,6 +8,8 @@ import { useSettingsPanel } from "../../context/SettingsPanelContext.es.js";
|
|
|
8
8
|
import "../../context/pip/PiPProvider.es.js";
|
|
9
9
|
import "react-dom";
|
|
10
10
|
import "../../context/pip/PiPWrapper.es.js";
|
|
11
|
+
import "../../context/AddonProjectContext.es.js";
|
|
12
|
+
import "../../context/AddonContext.es.js";
|
|
11
13
|
const SidePanel = styled.div`
|
|
12
14
|
height: 100%;
|
|
13
15
|
overflow: hidden;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SettingsPanel.es.js","sources":["../../../../../src/components/SettingsPanel/SettingsPanel.tsx"],"sourcesContent":["import { Button, Icon } from '@ynput/ayon-react-components'\nimport { FC, ReactNode } from 'react'\nimport styled from 'styled-components'\nimport { SettingField, useSettingsPanel } from '@shared/context'\n\n// Side panel styled components\nconst SidePanel = styled.div<{ open: boolean }>`\n height: 100%;\n overflow: hidden;\n background-color: var(--md-sys-color-surface-container-low);\n border-radius: 4px;\n z-index: 10;\n display: flex;\n flex-direction: column;\n`\n\nconst PanelHeader = styled.div`\n display: flex;\n align-items: center;\n gap: var(--base-gap-small);\n height: 34px;\n padding: 0px 4px;\n border-bottom: 1px solid var(--md-sys-color-outline-variant);\n\n h3 {\n margin-left: 4px;\n padding: 0;\n }\n`\n\nconst ToolButton = styled(Button)`\n padding: 4px !important;\n`\n\nconst PanelTitle = styled.h3`\n margin: 0;\n flex: 1;\n`\n\nconst PanelContent = styled.div`\n padding: 8px;\n flex: 1;\n overflow-y: auto;\n`\n\nexport const SettingOption = styled(Button)`\n width: 100%;\n justify-content: flex-start;\n margin-bottom: 8px;\n text-align: left;\n display: flex;\n gap: var(--base-gap-small);\n\n .title {\n flex: 1;\n }\n\n .preview {\n color: var(--md-sys-color-outline);\n }\n`\n\nexport interface SettingConfig {\n id: SettingField\n title: string\n component: ReactNode\n icon?: string\n preview?: string | number\n}\n\nexport interface SettingsPanelProps {\n settings: SettingConfig[]\n}\n\nexport const SettingsPanel: FC<SettingsPanelProps> = ({ settings }) => {\n const { isPanelOpen, selectedSetting, closePanel, backToMainMenu, selectSetting } =\n useSettingsPanel()\n\n const getPanelTitle = () => {\n if (!selectedSetting) return 'Settings'\n const setting = settings.find((s) => s.id === selectedSetting)\n return setting?.title || 'Settings'\n }\n\n const renderSettingContent = () => {\n if (!selectedSetting) {\n // Render main menu\n return (\n <>\n {settings.map((setting) => (\n <SettingOption\n key={setting.id}\n onClick={() => selectSetting(setting.id)}\n variant=\"text\"\n >\n {setting.icon && <Icon icon={setting.icon} />}\n <span className=\"title\">{setting.title}</span>\n {!!setting.preview?.toString() && <span className=\"preview\">{setting.preview}</span>}\n </SettingOption>\n ))}\n </>\n )\n }\n\n const setting = settings.find((s) => s.id === selectedSetting)\n return setting?.component\n }\n\n return (\n <SidePanel open={isPanelOpen}>\n <PanelHeader>\n {selectedSetting && settings.length > 1 && (\n <ToolButton variant=\"text\" icon=\"arrow_back\" onClick={backToMainMenu} />\n )}\n <PanelTitle>{getPanelTitle()}</PanelTitle>\n <ToolButton variant=\"text\" icon=\"close\" onClick={closePanel} />\n </PanelHeader>\n <PanelContent>{renderSettingContent()}</PanelContent>\n </SidePanel>\n )\n}\n"],"names":["jsx","Fragment","setting","jsxs"],"mappings":"
|
|
1
|
+
{"version":3,"file":"SettingsPanel.es.js","sources":["../../../../../src/components/SettingsPanel/SettingsPanel.tsx"],"sourcesContent":["import { Button, Icon } from '@ynput/ayon-react-components'\nimport { FC, ReactNode } from 'react'\nimport styled from 'styled-components'\nimport { SettingField, useSettingsPanel } from '@shared/context'\n\n// Side panel styled components\nconst SidePanel = styled.div<{ open: boolean }>`\n height: 100%;\n overflow: hidden;\n background-color: var(--md-sys-color-surface-container-low);\n border-radius: 4px;\n z-index: 10;\n display: flex;\n flex-direction: column;\n`\n\nconst PanelHeader = styled.div`\n display: flex;\n align-items: center;\n gap: var(--base-gap-small);\n height: 34px;\n padding: 0px 4px;\n border-bottom: 1px solid var(--md-sys-color-outline-variant);\n\n h3 {\n margin-left: 4px;\n padding: 0;\n }\n`\n\nconst ToolButton = styled(Button)`\n padding: 4px !important;\n`\n\nconst PanelTitle = styled.h3`\n margin: 0;\n flex: 1;\n`\n\nconst PanelContent = styled.div`\n padding: 8px;\n flex: 1;\n overflow-y: auto;\n`\n\nexport const SettingOption = styled(Button)`\n width: 100%;\n justify-content: flex-start;\n margin-bottom: 8px;\n text-align: left;\n display: flex;\n gap: var(--base-gap-small);\n\n .title {\n flex: 1;\n }\n\n .preview {\n color: var(--md-sys-color-outline);\n }\n`\n\nexport interface SettingConfig {\n id: SettingField\n title: string\n component: ReactNode\n icon?: string\n preview?: string | number\n}\n\nexport interface SettingsPanelProps {\n settings: SettingConfig[]\n}\n\nexport const SettingsPanel: FC<SettingsPanelProps> = ({ settings }) => {\n const { isPanelOpen, selectedSetting, closePanel, backToMainMenu, selectSetting } =\n useSettingsPanel()\n\n const getPanelTitle = () => {\n if (!selectedSetting) return 'Settings'\n const setting = settings.find((s) => s.id === selectedSetting)\n return setting?.title || 'Settings'\n }\n\n const renderSettingContent = () => {\n if (!selectedSetting) {\n // Render main menu\n return (\n <>\n {settings.map((setting) => (\n <SettingOption\n key={setting.id}\n onClick={() => selectSetting(setting.id)}\n variant=\"text\"\n >\n {setting.icon && <Icon icon={setting.icon} />}\n <span className=\"title\">{setting.title}</span>\n {!!setting.preview?.toString() && <span className=\"preview\">{setting.preview}</span>}\n </SettingOption>\n ))}\n </>\n )\n }\n\n const setting = settings.find((s) => s.id === selectedSetting)\n return setting?.component\n }\n\n return (\n <SidePanel open={isPanelOpen}>\n <PanelHeader>\n {selectedSetting && settings.length > 1 && (\n <ToolButton variant=\"text\" icon=\"arrow_back\" onClick={backToMainMenu} />\n )}\n <PanelTitle>{getPanelTitle()}</PanelTitle>\n <ToolButton variant=\"text\" icon=\"close\" onClick={closePanel} />\n </PanelHeader>\n <PanelContent>{renderSettingContent()}</PanelContent>\n </SidePanel>\n )\n}\n"],"names":["jsx","Fragment","setting","jsxs"],"mappings":";;;;;;;;;;;;AAMA,MAAM,YAAY,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAUzB,MAAM,cAAc,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAc3B,MAAM,aAAa,OAAO,MAAM;AAAA;AAAA;AAIhC,MAAM,aAAa,OAAO;AAAA;AAAA;AAAA;AAK1B,MAAM,eAAe,OAAO;AAAA;AAAA;AAAA;AAAA;AAMf,MAAA,gBAAgB,OAAO,MAAM;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AA6BnC,MAAM,gBAAwC,CAAC,EAAE,eAAe;AACrE,QAAM,EAAE,aAAa,iBAAiB,YAAY,gBAAgB,kBAChE,iBAAiB;AAEnB,QAAM,gBAAgB,MAAM;AACtB,QAAA,CAAC,gBAAwB,QAAA;AAC7B,UAAM,UAAU,SAAS,KAAK,CAAC,MAAM,EAAE,OAAO,eAAe;AAC7D,YAAO,mCAAS,UAAS;AAAA,EAC3B;AAEA,QAAM,uBAAuB,MAAM;AACjC,QAAI,CAAC,iBAAiB;AAEpB,aAEKA,kCAAAA,IAAAC,kBAAAA,UAAA,EAAA,UAAA,SAAS,IAAI,CAACC;;AACbC,iDAAA;AAAA,UAAC;AAAA,UAAA;AAAA,YAEC,SAAS,MAAM,cAAcD,SAAQ,EAAE;AAAA,YACvC,SAAQ;AAAA,YAEP,UAAA;AAAA,cAAAA,SAAQ,QAAQF,sCAAC,MAAK,EAAA,MAAME,SAAQ,MAAM;AAAA,oDAC1C,QAAK,EAAA,WAAU,SAAS,UAAAA,SAAQ,OAAM;AAAA,cACtC,CAAC,GAACA,cAAQ,YAARA,mBAAiB,eAAeF,kCAAA,IAAA,QAAA,EAAK,WAAU,WAAW,UAAAE,SAAQ,QAAQ,CAAA;AAAA,YAAA;AAAA,UAAA;AAAA,UANxEA,SAAQ;AAAA,QAQhB;AAAA,OAAA,GACH;AAAA,IAAA;AAIJ,UAAM,UAAU,SAAS,KAAK,CAAC,MAAM,EAAE,OAAO,eAAe;AAC7D,WAAO,mCAAS;AAAA,EAClB;AAGE,SAAAC,kCAAA,KAAC,WAAU,EAAA,MAAM,aACf,UAAA;AAAA,IAAAA,uCAAC,aACE,EAAA,UAAA;AAAA,MAAmB,mBAAA,SAAS,SAAS,KACnCH,kCAAA,IAAA,YAAA,EAAW,SAAQ,QAAO,MAAK,cAAa,SAAS,eAAgB,CAAA;AAAA,MAExEA,kCAAAA,IAAC,YAAY,EAAA,UAAA,cAAgB,EAAA,CAAA;AAAA,4CAC5B,YAAW,EAAA,SAAQ,QAAO,MAAK,SAAQ,SAAS,WAAY,CAAA;AAAA,IAAA,GAC/D;AAAA,IACAA,kCAAAA,IAAC,cAAc,EAAA,UAAA,qBAAA,EAAuB,CAAA;AAAA,EAAA,GACxC;AAEJ;"}
|
|
@@ -12,6 +12,8 @@ require("../../context/SettingsPanelContext.cjs.js");
|
|
|
12
12
|
require("../../context/pip/PiPProvider.cjs.js");
|
|
13
13
|
require("react-dom");
|
|
14
14
|
require("../../context/pip/PiPWrapper.cjs.js");
|
|
15
|
+
require("../../context/AddonProjectContext.cjs.js");
|
|
16
|
+
require("../../context/AddonContext.cjs.js");
|
|
15
17
|
const StackedStyled = styled.div`
|
|
16
18
|
display: flex;
|
|
17
19
|
z-index: 10;
|
|
@@ -44,6 +46,10 @@ const StackedStyled = styled.div`
|
|
|
44
46
|
& > * + * {
|
|
45
47
|
margin-left: ${({ $length }) => `${Math.max(-20, -$length * 1.5 - 8)}px`};
|
|
46
48
|
}
|
|
49
|
+
|
|
50
|
+
.thumbnail img {
|
|
51
|
+
object-fit: cover;
|
|
52
|
+
}
|
|
47
53
|
}
|
|
48
54
|
`;
|
|
49
55
|
const StackedThumbnails = ({
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"StackedThumbnails.cjs.js","sources":["../../../../../src/components/Thumbnail/StackedThumbnails.tsx"],"sourcesContent":["import React, { useContext } from 'react'\nimport styled, { css } from 'styled-components'\nimport { Thumbnail } from './Thumbnail'\nimport clsx from 'clsx'\nimport { ThumbnailUploadContext } from '@shared/context'\nimport { ThumbnailProps } from '@shared/components'\n\ntype StackedStyledProps = {\n $length: number\n}\n\nconst StackedStyled = styled.div<StackedStyledProps>`\n display: flex;\n z-index: 10;\n height: 100%;\n position: relative;\n overflow: hidden;\n border-radius: 8px;\n min-width: min-content;\n cursor: pointer;\n\n &.stacking {\n & > * {\n margin: unset;\n aspect-ratio: 1;\n border: solid 2px var(--md-sys-color-outline-variant);\n border-radius: 8px;\n\n span {\n font-size: 24px;\n }\n\n ${({ $length }) =>\n $length > 1 &&\n css`\n :not(:last-child) {\n box-shadow: 0 0 4px 0px black;\n }\n `}\n }\n\n /* create stacked effect */\n & > * + * {\n margin-left: ${({ $length }) => `${Math.max(-20, -$length * 1.5 - 8)}px`};\n }\n }\n`\n\ntype Thumbnail = {\n id?: string\n type?: string\n projectName?: string\n icon?: string\n updatedAt?: string\n src?: string\n}\n\nexport interface StackedThumbnailsProps\n extends Omit<ThumbnailProps, 'entityType' | 'entityId' | 'projectName'> {\n thumbnails?: Thumbnail[]\n isLoading?: boolean\n className?: string\n style?: React.CSSProperties\n}\n\nexport const StackedThumbnails = ({\n thumbnails = [],\n isLoading,\n className,\n style,\n ...props\n}: StackedThumbnailsProps) => {\n const { onContextMenu } = useContext(ThumbnailUploadContext)\n // limit to 5 users\n thumbnails = thumbnails.slice(0, 5)\n const isStacking = thumbnails.length > 1\n\n if (!thumbnails.length) return null\n\n return (\n <StackedStyled\n $length={thumbnails.length}\n className={clsx('stacked-thumbnails', className, { stacking: isStacking })}\n >\n {thumbnails.map((thumb, i) =>\n thumb ? (\n <Thumbnail\n projectName={thumb.projectName}\n entityType={thumb.type}\n entityId={thumb.id}\n icon={thumb.icon}\n key={thumb.id || thumb.src || i}\n style={{ ...style, zIndex: -i }}\n entityUpdatedAt={thumb.updatedAt}\n isLoading={isLoading}\n src={thumb.src}\n // @ts-ignore\n onContextMenu={onContextMenu}\n {...props}\n />\n ) : null,\n )}\n </StackedStyled>\n )\n}\n"],"names":["css","useContext","ThumbnailUploadContext","jsx","Thumbnail"],"mappings":"
|
|
1
|
+
{"version":3,"file":"StackedThumbnails.cjs.js","sources":["../../../../../src/components/Thumbnail/StackedThumbnails.tsx"],"sourcesContent":["import React, { useContext } from 'react'\nimport styled, { css } from 'styled-components'\nimport { Thumbnail } from './Thumbnail'\nimport clsx from 'clsx'\nimport { ThumbnailUploadContext } from '@shared/context'\nimport { ThumbnailProps } from '@shared/components'\n\ntype StackedStyledProps = {\n $length: number\n}\n\nconst StackedStyled = styled.div<StackedStyledProps>`\n display: flex;\n z-index: 10;\n height: 100%;\n position: relative;\n overflow: hidden;\n border-radius: 8px;\n min-width: min-content;\n cursor: pointer;\n\n &.stacking {\n & > * {\n margin: unset;\n aspect-ratio: 1;\n border: solid 2px var(--md-sys-color-outline-variant);\n border-radius: 8px;\n\n span {\n font-size: 24px;\n }\n\n ${({ $length }) =>\n $length > 1 &&\n css`\n :not(:last-child) {\n box-shadow: 0 0 4px 0px black;\n }\n `}\n }\n\n /* create stacked effect */\n & > * + * {\n margin-left: ${({ $length }) => `${Math.max(-20, -$length * 1.5 - 8)}px`};\n }\n\n .thumbnail img {\n object-fit: cover;\n }\n }\n`\n\ntype Thumbnail = {\n id?: string\n type?: string\n projectName?: string\n icon?: string\n updatedAt?: string\n src?: string\n}\n\nexport interface StackedThumbnailsProps\n extends Omit<ThumbnailProps, 'entityType' | 'entityId' | 'projectName'> {\n thumbnails?: Thumbnail[]\n isLoading?: boolean\n className?: string\n style?: React.CSSProperties\n}\n\nexport const StackedThumbnails = ({\n thumbnails = [],\n isLoading,\n className,\n style,\n ...props\n}: StackedThumbnailsProps) => {\n const { onContextMenu } = useContext(ThumbnailUploadContext)\n // limit to 5 users\n thumbnails = thumbnails.slice(0, 5)\n const isStacking = thumbnails.length > 1\n\n if (!thumbnails.length) return null\n\n return (\n <StackedStyled\n $length={thumbnails.length}\n className={clsx('stacked-thumbnails', className, { stacking: isStacking })}\n >\n {thumbnails.map((thumb, i) =>\n thumb ? (\n <Thumbnail\n projectName={thumb.projectName}\n entityType={thumb.type}\n entityId={thumb.id}\n icon={thumb.icon}\n key={thumb.id || thumb.src || i}\n style={{ ...style, zIndex: -i }}\n entityUpdatedAt={thumb.updatedAt}\n isLoading={isLoading}\n src={thumb.src}\n // @ts-ignore\n onContextMenu={onContextMenu}\n {...props}\n />\n ) : null,\n )}\n </StackedStyled>\n )\n}\n"],"names":["css","useContext","ThumbnailUploadContext","jsx","Thumbnail"],"mappings":";;;;;;;;;;;;;;;;AAWA,MAAM,gBAAgB,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,QAqBrB,CAAC,EAAE,QAAQ,MACX,UAAU,KACVA,OAAA;AAAA;AAAA;AAAA;AAAA,SAIC;AAAA;AAAA;AAAA;AAAA;AAAA,qBAKY,CAAC,EAAE,QAAQ,MAAM,GAAG,KAAK,IAAI,KAAK,CAAC,UAAU,MAAM,CAAC,CAAC,IAAI;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AA0BvE,MAAM,oBAAoB,CAAC;AAAA,EAChC,aAAa,CAAC;AAAA,EACd;AAAA,EACA;AAAA,EACA;AAAA,EACA,GAAG;AACL,MAA8B;AAC5B,QAAM,EAAE,cAAA,IAAkBC,MAAA,WAAWC,+CAAsB;AAE9C,eAAA,WAAW,MAAM,GAAG,CAAC;AAC5B,QAAA,aAAa,WAAW,SAAS;AAEnC,MAAA,CAAC,WAAW,OAAe,QAAA;AAG7B,SAAAC,2BAAA,kBAAA;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,SAAS,WAAW;AAAA,MACpB,WAAW,KAAK,sBAAsB,WAAW,EAAE,UAAU,YAAY;AAAA,MAExE,UAAW,WAAA;AAAA,QAAI,CAAC,OAAO,MACtB,QACEA,2BAAA,kBAAA;AAAA,UAACC,UAAA;AAAA,UAAA;AAAA,YACC,aAAa,MAAM;AAAA,YACnB,YAAY,MAAM;AAAA,YAClB,UAAU,MAAM;AAAA,YAChB,MAAM,MAAM;AAAA,YAEZ,OAAO,EAAE,GAAG,OAAO,QAAQ,CAAC,EAAE;AAAA,YAC9B,iBAAiB,MAAM;AAAA,YACvB;AAAA,YACA,KAAK,MAAM;AAAA,YAEX;AAAA,YACC,GAAG;AAAA,UAAA;AAAA,UAPC,MAAM,MAAM,MAAM,OAAO;AAAA,QAAA,IAS9B;AAAA,MAAA;AAAA,IACN;AAAA,EACF;AAEJ;;"}
|
|
@@ -10,6 +10,8 @@ import "../../context/SettingsPanelContext.es.js";
|
|
|
10
10
|
import "../../context/pip/PiPProvider.es.js";
|
|
11
11
|
import "react-dom";
|
|
12
12
|
import "../../context/pip/PiPWrapper.es.js";
|
|
13
|
+
import "../../context/AddonProjectContext.es.js";
|
|
14
|
+
import "../../context/AddonContext.es.js";
|
|
13
15
|
const StackedStyled = styled.div`
|
|
14
16
|
display: flex;
|
|
15
17
|
z-index: 10;
|
|
@@ -42,6 +44,10 @@ const StackedStyled = styled.div`
|
|
|
42
44
|
& > * + * {
|
|
43
45
|
margin-left: ${({ $length }) => `${Math.max(-20, -$length * 1.5 - 8)}px`};
|
|
44
46
|
}
|
|
47
|
+
|
|
48
|
+
.thumbnail img {
|
|
49
|
+
object-fit: cover;
|
|
50
|
+
}
|
|
45
51
|
}
|
|
46
52
|
`;
|
|
47
53
|
const StackedThumbnails = ({
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"StackedThumbnails.es.js","sources":["../../../../../src/components/Thumbnail/StackedThumbnails.tsx"],"sourcesContent":["import React, { useContext } from 'react'\nimport styled, { css } from 'styled-components'\nimport { Thumbnail } from './Thumbnail'\nimport clsx from 'clsx'\nimport { ThumbnailUploadContext } from '@shared/context'\nimport { ThumbnailProps } from '@shared/components'\n\ntype StackedStyledProps = {\n $length: number\n}\n\nconst StackedStyled = styled.div<StackedStyledProps>`\n display: flex;\n z-index: 10;\n height: 100%;\n position: relative;\n overflow: hidden;\n border-radius: 8px;\n min-width: min-content;\n cursor: pointer;\n\n &.stacking {\n & > * {\n margin: unset;\n aspect-ratio: 1;\n border: solid 2px var(--md-sys-color-outline-variant);\n border-radius: 8px;\n\n span {\n font-size: 24px;\n }\n\n ${({ $length }) =>\n $length > 1 &&\n css`\n :not(:last-child) {\n box-shadow: 0 0 4px 0px black;\n }\n `}\n }\n\n /* create stacked effect */\n & > * + * {\n margin-left: ${({ $length }) => `${Math.max(-20, -$length * 1.5 - 8)}px`};\n }\n }\n`\n\ntype Thumbnail = {\n id?: string\n type?: string\n projectName?: string\n icon?: string\n updatedAt?: string\n src?: string\n}\n\nexport interface StackedThumbnailsProps\n extends Omit<ThumbnailProps, 'entityType' | 'entityId' | 'projectName'> {\n thumbnails?: Thumbnail[]\n isLoading?: boolean\n className?: string\n style?: React.CSSProperties\n}\n\nexport const StackedThumbnails = ({\n thumbnails = [],\n isLoading,\n className,\n style,\n ...props\n}: StackedThumbnailsProps) => {\n const { onContextMenu } = useContext(ThumbnailUploadContext)\n // limit to 5 users\n thumbnails = thumbnails.slice(0, 5)\n const isStacking = thumbnails.length > 1\n\n if (!thumbnails.length) return null\n\n return (\n <StackedStyled\n $length={thumbnails.length}\n className={clsx('stacked-thumbnails', className, { stacking: isStacking })}\n >\n {thumbnails.map((thumb, i) =>\n thumb ? (\n <Thumbnail\n projectName={thumb.projectName}\n entityType={thumb.type}\n entityId={thumb.id}\n icon={thumb.icon}\n key={thumb.id || thumb.src || i}\n style={{ ...style, zIndex: -i }}\n entityUpdatedAt={thumb.updatedAt}\n isLoading={isLoading}\n src={thumb.src}\n // @ts-ignore\n onContextMenu={onContextMenu}\n {...props}\n />\n ) : null,\n )}\n </StackedStyled>\n )\n}\n"],"names":["jsx"],"mappings":"
|
|
1
|
+
{"version":3,"file":"StackedThumbnails.es.js","sources":["../../../../../src/components/Thumbnail/StackedThumbnails.tsx"],"sourcesContent":["import React, { useContext } from 'react'\nimport styled, { css } from 'styled-components'\nimport { Thumbnail } from './Thumbnail'\nimport clsx from 'clsx'\nimport { ThumbnailUploadContext } from '@shared/context'\nimport { ThumbnailProps } from '@shared/components'\n\ntype StackedStyledProps = {\n $length: number\n}\n\nconst StackedStyled = styled.div<StackedStyledProps>`\n display: flex;\n z-index: 10;\n height: 100%;\n position: relative;\n overflow: hidden;\n border-radius: 8px;\n min-width: min-content;\n cursor: pointer;\n\n &.stacking {\n & > * {\n margin: unset;\n aspect-ratio: 1;\n border: solid 2px var(--md-sys-color-outline-variant);\n border-radius: 8px;\n\n span {\n font-size: 24px;\n }\n\n ${({ $length }) =>\n $length > 1 &&\n css`\n :not(:last-child) {\n box-shadow: 0 0 4px 0px black;\n }\n `}\n }\n\n /* create stacked effect */\n & > * + * {\n margin-left: ${({ $length }) => `${Math.max(-20, -$length * 1.5 - 8)}px`};\n }\n\n .thumbnail img {\n object-fit: cover;\n }\n }\n`\n\ntype Thumbnail = {\n id?: string\n type?: string\n projectName?: string\n icon?: string\n updatedAt?: string\n src?: string\n}\n\nexport interface StackedThumbnailsProps\n extends Omit<ThumbnailProps, 'entityType' | 'entityId' | 'projectName'> {\n thumbnails?: Thumbnail[]\n isLoading?: boolean\n className?: string\n style?: React.CSSProperties\n}\n\nexport const StackedThumbnails = ({\n thumbnails = [],\n isLoading,\n className,\n style,\n ...props\n}: StackedThumbnailsProps) => {\n const { onContextMenu } = useContext(ThumbnailUploadContext)\n // limit to 5 users\n thumbnails = thumbnails.slice(0, 5)\n const isStacking = thumbnails.length > 1\n\n if (!thumbnails.length) return null\n\n return (\n <StackedStyled\n $length={thumbnails.length}\n className={clsx('stacked-thumbnails', className, { stacking: isStacking })}\n >\n {thumbnails.map((thumb, i) =>\n thumb ? (\n <Thumbnail\n projectName={thumb.projectName}\n entityType={thumb.type}\n entityId={thumb.id}\n icon={thumb.icon}\n key={thumb.id || thumb.src || i}\n style={{ ...style, zIndex: -i }}\n entityUpdatedAt={thumb.updatedAt}\n isLoading={isLoading}\n src={thumb.src}\n // @ts-ignore\n onContextMenu={onContextMenu}\n {...props}\n />\n ) : null,\n )}\n </StackedStyled>\n )\n}\n"],"names":["jsx"],"mappings":";;;;;;;;;;;;;;AAWA,MAAM,gBAAgB,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,QAqBrB,CAAC,EAAE,QAAQ,MACX,UAAU,KACV;AAAA;AAAA;AAAA;AAAA,SAIC;AAAA;AAAA;AAAA;AAAA;AAAA,qBAKY,CAAC,EAAE,QAAQ,MAAM,GAAG,KAAK,IAAI,KAAK,CAAC,UAAU,MAAM,CAAC,CAAC,IAAI;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AA0BvE,MAAM,oBAAoB,CAAC;AAAA,EAChC,aAAa,CAAC;AAAA,EACd;AAAA,EACA;AAAA,EACA;AAAA,EACA,GAAG;AACL,MAA8B;AAC5B,QAAM,EAAE,cAAA,IAAkB,WAAW,sBAAsB;AAE9C,eAAA,WAAW,MAAM,GAAG,CAAC;AAC5B,QAAA,aAAa,WAAW,SAAS;AAEnC,MAAA,CAAC,WAAW,OAAe,QAAA;AAG7B,SAAAA,kCAAA;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,SAAS,WAAW;AAAA,MACpB,WAAW,KAAK,sBAAsB,WAAW,EAAE,UAAU,YAAY;AAAA,MAExE,UAAW,WAAA;AAAA,QAAI,CAAC,OAAO,MACtB,QACEA,kCAAA;AAAA,UAAC;AAAA,UAAA;AAAA,YACC,aAAa,MAAM;AAAA,YACnB,YAAY,MAAM;AAAA,YAClB,UAAU,MAAM;AAAA,YAChB,MAAM,MAAM;AAAA,YAEZ,OAAO,EAAE,GAAG,OAAO,QAAQ,CAAC,EAAE;AAAA,YAC9B,iBAAiB,MAAM;AAAA,YACvB;AAAA,YACA,KAAK,MAAM;AAAA,YAEX;AAAA,YACC,GAAG;AAAA,UAAA;AAAA,UAPC,MAAM,MAAM,MAAM,OAAO;AAAA,QAAA,IAS9B;AAAA,MAAA;AAAA,IACN;AAAA,EACF;AAEJ;"}
|
|
@@ -5,7 +5,7 @@ const Card = styled.div`
|
|
|
5
5
|
position: relative;
|
|
6
6
|
width: 100%;
|
|
7
7
|
height: 52px;
|
|
8
|
-
aspect-ratio: 1.
|
|
8
|
+
aspect-ratio: 1.7;
|
|
9
9
|
overflow: hidden;
|
|
10
10
|
border-radius: var(--border-radius-l);
|
|
11
11
|
margin: auto;
|
|
@@ -72,12 +72,7 @@ const Card = styled.div`
|
|
|
72
72
|
cursor: pointer;
|
|
73
73
|
|
|
74
74
|
&:hover {
|
|
75
|
-
&.loaded:not(.error) {
|
|
76
|
-
background-color: var(--md-sys-color-on-surface);
|
|
77
|
-
}
|
|
78
|
-
|
|
79
75
|
img {
|
|
80
|
-
opacity: 0.9;
|
|
81
76
|
scale: 1.1;
|
|
82
77
|
}
|
|
83
78
|
|
|
@@ -101,7 +96,7 @@ const Card = styled.div`
|
|
|
101
96
|
const Image = styled.img`
|
|
102
97
|
width: 100%;
|
|
103
98
|
height: 100%;
|
|
104
|
-
object-fit:
|
|
99
|
+
object-fit: contain;
|
|
105
100
|
border-radius: var(--border-radius-m);
|
|
106
101
|
overflow: hidden;
|
|
107
102
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Thumbnail.styled.cjs.js","sources":["../../../../../src/components/Thumbnail/Thumbnail.styled.ts"],"sourcesContent":["import styled from 'styled-components'\n\nexport const Card = styled.div`\n position: relative;\n width: 100%;\n height: 52px;\n aspect-ratio: 1.
|
|
1
|
+
{"version":3,"file":"Thumbnail.styled.cjs.js","sources":["../../../../../src/components/Thumbnail/Thumbnail.styled.ts"],"sourcesContent":["import styled from 'styled-components'\n\nexport const Card = styled.div`\n position: relative;\n width: 100%;\n height: 52px;\n aspect-ratio: 1.7;\n overflow: hidden;\n border-radius: var(--border-radius-l);\n margin: auto;\n\n background-color: var(--md-sys-color-surface-container-lowest);\n\n transition: border-color 0.2s, background-color 0.2s;\n\n &.border {\n border: solid 2px var(--md-sys-color-outline-variant);\n }\n\n /* icon */\n .icon {\n position: absolute;\n user-select: none;\n display: flex;\n justify-content: center;\n align-items: center;\n inset: 0;\n\n transition: opacity 0.2s;\n }\n\n .type-icon {\n color: var(--md-sys-color-outline);\n }\n\n .hover-icon {\n inset: unset;\n left: 50%;\n top: 50%;\n transform: translate(-50%, -50%);\n font-size: 30px;\n\n border-radius: 50%;\n\n background-color: rgba(0, 0, 0, 0.7);\n }\n\n /* hide the image until it has been loaded */\n img,\n .icon {\n opacity: 0;\n }\n\n &.loaded {\n /* show img if not error otherwise show icon */\n &:not(.error) {\n img {\n opacity: 1;\n }\n }\n\n /* show icon if error */\n &.error {\n .type-icon {\n opacity: 1;\n }\n }\n }\n\n &.clickable {\n cursor: pointer;\n\n &:hover {\n img {\n scale: 1.1;\n }\n\n /* show play icon */\n .hover-icon {\n opacity: 1;\n }\n\n /* if :has a hover-icon hide the type-cion */\n .type-icon {\n opacity: 0;\n }\n }\n }\n\n &.loading {\n border: none;\n border-color: transparent;\n }\n`\n\nexport const Image = styled.img`\n width: 100%;\n height: 100%;\n object-fit: contain;\n border-radius: var(--border-radius-m);\n overflow: hidden;\n\n /* ensures it always fills the parent */\n display: block;\n position: absolute;\n inset: 0;\n\n transition: scale 0.2s, opacity 0.2s;\n`\n"],"names":[],"mappings":";;;AAEO,MAAM,OAAO,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AA6FpB,MAAM,QAAQ,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;"}
|
|
@@ -3,7 +3,7 @@ const Card = styled.div`
|
|
|
3
3
|
position: relative;
|
|
4
4
|
width: 100%;
|
|
5
5
|
height: 52px;
|
|
6
|
-
aspect-ratio: 1.
|
|
6
|
+
aspect-ratio: 1.7;
|
|
7
7
|
overflow: hidden;
|
|
8
8
|
border-radius: var(--border-radius-l);
|
|
9
9
|
margin: auto;
|
|
@@ -70,12 +70,7 @@ const Card = styled.div`
|
|
|
70
70
|
cursor: pointer;
|
|
71
71
|
|
|
72
72
|
&:hover {
|
|
73
|
-
&.loaded:not(.error) {
|
|
74
|
-
background-color: var(--md-sys-color-on-surface);
|
|
75
|
-
}
|
|
76
|
-
|
|
77
73
|
img {
|
|
78
|
-
opacity: 0.9;
|
|
79
74
|
scale: 1.1;
|
|
80
75
|
}
|
|
81
76
|
|
|
@@ -99,7 +94,7 @@ const Card = styled.div`
|
|
|
99
94
|
const Image = styled.img`
|
|
100
95
|
width: 100%;
|
|
101
96
|
height: 100%;
|
|
102
|
-
object-fit:
|
|
97
|
+
object-fit: contain;
|
|
103
98
|
border-radius: var(--border-radius-m);
|
|
104
99
|
overflow: hidden;
|
|
105
100
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Thumbnail.styled.es.js","sources":["../../../../../src/components/Thumbnail/Thumbnail.styled.ts"],"sourcesContent":["import styled from 'styled-components'\n\nexport const Card = styled.div`\n position: relative;\n width: 100%;\n height: 52px;\n aspect-ratio: 1.
|
|
1
|
+
{"version":3,"file":"Thumbnail.styled.es.js","sources":["../../../../../src/components/Thumbnail/Thumbnail.styled.ts"],"sourcesContent":["import styled from 'styled-components'\n\nexport const Card = styled.div`\n position: relative;\n width: 100%;\n height: 52px;\n aspect-ratio: 1.7;\n overflow: hidden;\n border-radius: var(--border-radius-l);\n margin: auto;\n\n background-color: var(--md-sys-color-surface-container-lowest);\n\n transition: border-color 0.2s, background-color 0.2s;\n\n &.border {\n border: solid 2px var(--md-sys-color-outline-variant);\n }\n\n /* icon */\n .icon {\n position: absolute;\n user-select: none;\n display: flex;\n justify-content: center;\n align-items: center;\n inset: 0;\n\n transition: opacity 0.2s;\n }\n\n .type-icon {\n color: var(--md-sys-color-outline);\n }\n\n .hover-icon {\n inset: unset;\n left: 50%;\n top: 50%;\n transform: translate(-50%, -50%);\n font-size: 30px;\n\n border-radius: 50%;\n\n background-color: rgba(0, 0, 0, 0.7);\n }\n\n /* hide the image until it has been loaded */\n img,\n .icon {\n opacity: 0;\n }\n\n &.loaded {\n /* show img if not error otherwise show icon */\n &:not(.error) {\n img {\n opacity: 1;\n }\n }\n\n /* show icon if error */\n &.error {\n .type-icon {\n opacity: 1;\n }\n }\n }\n\n &.clickable {\n cursor: pointer;\n\n &:hover {\n img {\n scale: 1.1;\n }\n\n /* show play icon */\n .hover-icon {\n opacity: 1;\n }\n\n /* if :has a hover-icon hide the type-cion */\n .type-icon {\n opacity: 0;\n }\n }\n }\n\n &.loading {\n border: none;\n border-color: transparent;\n }\n`\n\nexport const Image = styled.img`\n width: 100%;\n height: 100%;\n object-fit: contain;\n border-radius: var(--border-radius-m);\n overflow: hidden;\n\n /* ensures it always fills the parent */\n display: block;\n position: absolute;\n inset: 0;\n\n transition: scale 0.2s, opacity 0.2s;\n`\n"],"names":[],"mappings":";AAEO,MAAM,OAAO,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AA6FpB,MAAM,QAAQ,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;"}
|
|
@@ -65,6 +65,7 @@ require("../../api/queries/userDashboard/getUserDashboard.cjs.js");
|
|
|
65
65
|
require("../../api/queries/users/getUsers.cjs.js");
|
|
66
66
|
require("../../api/queries/users/updateUsers.cjs.js");
|
|
67
67
|
const getWatchers = require("../../api/queries/watchers/getWatchers.cjs.js");
|
|
68
|
+
require("../../api/queries/permissions/getPermissions.cjs.js");
|
|
68
69
|
const ayonReactComponents = require("@ynput/ayon-react-components");
|
|
69
70
|
const React = require("react");
|
|
70
71
|
const reactToastify = require("react-toastify");
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Watchers.cjs.js","sources":["../../../../../src/components/Watchers/Watchers.tsx"],"sourcesContent":["import { useGetEntitiesWatchersQuery, useSetEntitiesWatchersMutation } from '@shared/api'\nimport { DropdownRef, WatcherSelect, WatcherSelectProps } from '@ynput/ayon-react-components'\nimport { forwardRef } from 'react'\nimport { toast } from 'react-toastify'\n\ninterface WatchersProps extends Omit<WatcherSelectProps, 'currentUser' | 'value'> {\n entities: { id: string; projectName: string }[]\n entityType: string\n onWatchersUpdate?: (added: any[], removed: any[]) => void\n userName: string\n}\n\nexport const Watchers = forwardRef<DropdownRef, WatchersProps>(\n ({ entities, entityType, onWatchersUpdate, userName, ...props }, ref) => {\n const entitiesQuery = entities.map((entity) => ({\n entityId: entity.id,\n entityType,\n projectName: entity.projectName,\n }))\n\n const { data: watchers = [] } = useGetEntitiesWatchersQuery(\n {\n entities: entitiesQuery,\n },\n { skip: !entities.length },\n )\n\n // merge all watchers into a single unique array\n const uniqueWatchers = Array.from(new Set(watchers.flatMap((watcher) => watcher.watchers)))\n\n const [setEntitiesWatchers] = useSetEntitiesWatchersMutation()\n\n const handleChange = async (value: string[]) => {\n // find the difference between the current watchers and the new watchers\n // which users were added and which were removed\n const added = value.filter((watcher) => !uniqueWatchers.includes(watcher))\n const removed = uniqueWatchers.filter((watcher) => !value.includes(watcher))\n\n // for each entity, add or remove the watchers\n // we do this to preserve the unique watchers for each entity (rather than setting the same watchers for all entities)\n const updatedEntities = watchers.map((entity) => {\n // first remove\n const newWatchers = entity.watchers.filter((watcher) => !removed.includes(watcher))\n // then add\n newWatchers.push(...added)\n\n return {\n ...entity,\n watchers: newWatchers,\n }\n })\n\n // update\n try {\n await setEntitiesWatchers({ entities: updatedEntities }).unwrap()\n onWatchersUpdate && onWatchersUpdate(added, removed)\n } catch (error) {\n toast.error('Failed to update watchers')\n }\n }\n\n return (\n <WatcherSelect\n align=\"right\"\n {...props}\n value={uniqueWatchers}\n currentUser={userName}\n onChange={handleChange}\n ref={ref}\n // @ts-expect-error\n buttonProps={{ 'data-tooltip': 'Watchers' }}\n />\n )\n },\n)\n"],"names":["forwardRef","useGetEntitiesWatchersQuery","useSetEntitiesWatchersMutation","toast","jsx","WatcherSelect"],"mappings":"
|
|
1
|
+
{"version":3,"file":"Watchers.cjs.js","sources":["../../../../../src/components/Watchers/Watchers.tsx"],"sourcesContent":["import { useGetEntitiesWatchersQuery, useSetEntitiesWatchersMutation } from '@shared/api'\nimport { DropdownRef, WatcherSelect, WatcherSelectProps } from '@ynput/ayon-react-components'\nimport { forwardRef } from 'react'\nimport { toast } from 'react-toastify'\n\ninterface WatchersProps extends Omit<WatcherSelectProps, 'currentUser' | 'value'> {\n entities: { id: string; projectName: string }[]\n entityType: string\n onWatchersUpdate?: (added: any[], removed: any[]) => void\n userName: string\n}\n\nexport const Watchers = forwardRef<DropdownRef, WatchersProps>(\n ({ entities, entityType, onWatchersUpdate, userName, ...props }, ref) => {\n const entitiesQuery = entities.map((entity) => ({\n entityId: entity.id,\n entityType,\n projectName: entity.projectName,\n }))\n\n const { data: watchers = [] } = useGetEntitiesWatchersQuery(\n {\n entities: entitiesQuery,\n },\n { skip: !entities.length },\n )\n\n // merge all watchers into a single unique array\n const uniqueWatchers = Array.from(new Set(watchers.flatMap((watcher) => watcher.watchers)))\n\n const [setEntitiesWatchers] = useSetEntitiesWatchersMutation()\n\n const handleChange = async (value: string[]) => {\n // find the difference between the current watchers and the new watchers\n // which users were added and which were removed\n const added = value.filter((watcher) => !uniqueWatchers.includes(watcher))\n const removed = uniqueWatchers.filter((watcher) => !value.includes(watcher))\n\n // for each entity, add or remove the watchers\n // we do this to preserve the unique watchers for each entity (rather than setting the same watchers for all entities)\n const updatedEntities = watchers.map((entity) => {\n // first remove\n const newWatchers = entity.watchers.filter((watcher) => !removed.includes(watcher))\n // then add\n newWatchers.push(...added)\n\n return {\n ...entity,\n watchers: newWatchers,\n }\n })\n\n // update\n try {\n await setEntitiesWatchers({ entities: updatedEntities }).unwrap()\n onWatchersUpdate && onWatchersUpdate(added, removed)\n } catch (error) {\n toast.error('Failed to update watchers')\n }\n }\n\n return (\n <WatcherSelect\n align=\"right\"\n {...props}\n value={uniqueWatchers}\n currentUser={userName}\n onChange={handleChange}\n ref={ref}\n // @ts-expect-error\n buttonProps={{ 'data-tooltip': 'Watchers' }}\n />\n )\n },\n)\n"],"names":["forwardRef","useGetEntitiesWatchersQuery","useSetEntitiesWatchersMutation","toast","jsx","WatcherSelect"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAYO,MAAM,WAAWA,MAAA;AAAA,EACtB,CAAC,EAAE,UAAU,YAAY,kBAAkB,UAAU,GAAG,MAAM,GAAG,QAAQ;AACvE,UAAM,gBAAgB,SAAS,IAAI,CAAC,YAAY;AAAA,MAC9C,UAAU,OAAO;AAAA,MACjB;AAAA,MACA,aAAa,OAAO;AAAA,IAAA,EACpB;AAEF,UAAM,EAAE,MAAM,WAAW,CAAA,EAAO,IAAAC,YAAA;AAAA,MAC9B;AAAA,QACE,UAAU;AAAA,MACZ;AAAA,MACA,EAAE,MAAM,CAAC,SAAS,OAAO;AAAA,IAC3B;AAGA,UAAM,iBAAiB,MAAM,KAAK,IAAI,IAAI,SAAS,QAAQ,CAAC,YAAY,QAAQ,QAAQ,CAAC,CAAC;AAEpF,UAAA,CAAC,mBAAmB,IAAIC,2CAA+B;AAEvD,UAAA,eAAe,OAAO,UAAoB;AAGxC,YAAA,QAAQ,MAAM,OAAO,CAAC,YAAY,CAAC,eAAe,SAAS,OAAO,CAAC;AACnE,YAAA,UAAU,eAAe,OAAO,CAAC,YAAY,CAAC,MAAM,SAAS,OAAO,CAAC;AAI3E,YAAM,kBAAkB,SAAS,IAAI,CAAC,WAAW;AAEzC,cAAA,cAAc,OAAO,SAAS,OAAO,CAAC,YAAY,CAAC,QAAQ,SAAS,OAAO,CAAC;AAEtE,oBAAA,KAAK,GAAG,KAAK;AAElB,eAAA;AAAA,UACL,GAAG;AAAA,UACH,UAAU;AAAA,QACZ;AAAA,MAAA,CACD;AAGG,UAAA;AACF,cAAM,oBAAoB,EAAE,UAAU,gBAAiB,CAAA,EAAE,OAAO;AAC5C,4BAAA,iBAAiB,OAAO,OAAO;AAAA,eAC5C,OAAO;AACdC,sBAAA,MAAM,MAAM,2BAA2B;AAAA,MAAA;AAAA,IAE3C;AAGE,WAAAC,2BAAA,kBAAA;AAAA,MAACC,oBAAA;AAAA,MAAA;AAAA,QACC,OAAM;AAAA,QACL,GAAG;AAAA,QACJ,OAAO;AAAA,QACP,aAAa;AAAA,QACb,UAAU;AAAA,QACV;AAAA,QAEA,aAAa,EAAE,gBAAgB,WAAW;AAAA,MAAA;AAAA,IAC5C;AAAA,EAAA;AAGN;;"}
|
|
@@ -63,6 +63,7 @@ import "../../api/queries/userDashboard/getUserDashboard.es.js";
|
|
|
63
63
|
import "../../api/queries/users/getUsers.es.js";
|
|
64
64
|
import "../../api/queries/users/updateUsers.es.js";
|
|
65
65
|
import { useGetEntitiesWatchersQuery, useSetEntitiesWatchersMutation } from "../../api/queries/watchers/getWatchers.es.js";
|
|
66
|
+
import "../../api/queries/permissions/getPermissions.es.js";
|
|
66
67
|
import { WatcherSelect } from "@ynput/ayon-react-components";
|
|
67
68
|
import { forwardRef } from "react";
|
|
68
69
|
import { toast } from "react-toastify";
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Watchers.es.js","sources":["../../../../../src/components/Watchers/Watchers.tsx"],"sourcesContent":["import { useGetEntitiesWatchersQuery, useSetEntitiesWatchersMutation } from '@shared/api'\nimport { DropdownRef, WatcherSelect, WatcherSelectProps } from '@ynput/ayon-react-components'\nimport { forwardRef } from 'react'\nimport { toast } from 'react-toastify'\n\ninterface WatchersProps extends Omit<WatcherSelectProps, 'currentUser' | 'value'> {\n entities: { id: string; projectName: string }[]\n entityType: string\n onWatchersUpdate?: (added: any[], removed: any[]) => void\n userName: string\n}\n\nexport const Watchers = forwardRef<DropdownRef, WatchersProps>(\n ({ entities, entityType, onWatchersUpdate, userName, ...props }, ref) => {\n const entitiesQuery = entities.map((entity) => ({\n entityId: entity.id,\n entityType,\n projectName: entity.projectName,\n }))\n\n const { data: watchers = [] } = useGetEntitiesWatchersQuery(\n {\n entities: entitiesQuery,\n },\n { skip: !entities.length },\n )\n\n // merge all watchers into a single unique array\n const uniqueWatchers = Array.from(new Set(watchers.flatMap((watcher) => watcher.watchers)))\n\n const [setEntitiesWatchers] = useSetEntitiesWatchersMutation()\n\n const handleChange = async (value: string[]) => {\n // find the difference between the current watchers and the new watchers\n // which users were added and which were removed\n const added = value.filter((watcher) => !uniqueWatchers.includes(watcher))\n const removed = uniqueWatchers.filter((watcher) => !value.includes(watcher))\n\n // for each entity, add or remove the watchers\n // we do this to preserve the unique watchers for each entity (rather than setting the same watchers for all entities)\n const updatedEntities = watchers.map((entity) => {\n // first remove\n const newWatchers = entity.watchers.filter((watcher) => !removed.includes(watcher))\n // then add\n newWatchers.push(...added)\n\n return {\n ...entity,\n watchers: newWatchers,\n }\n })\n\n // update\n try {\n await setEntitiesWatchers({ entities: updatedEntities }).unwrap()\n onWatchersUpdate && onWatchersUpdate(added, removed)\n } catch (error) {\n toast.error('Failed to update watchers')\n }\n }\n\n return (\n <WatcherSelect\n align=\"right\"\n {...props}\n value={uniqueWatchers}\n currentUser={userName}\n onChange={handleChange}\n ref={ref}\n // @ts-expect-error\n buttonProps={{ 'data-tooltip': 'Watchers' }}\n />\n )\n },\n)\n"],"names":["jsx"],"mappings":"
|
|
1
|
+
{"version":3,"file":"Watchers.es.js","sources":["../../../../../src/components/Watchers/Watchers.tsx"],"sourcesContent":["import { useGetEntitiesWatchersQuery, useSetEntitiesWatchersMutation } from '@shared/api'\nimport { DropdownRef, WatcherSelect, WatcherSelectProps } from '@ynput/ayon-react-components'\nimport { forwardRef } from 'react'\nimport { toast } from 'react-toastify'\n\ninterface WatchersProps extends Omit<WatcherSelectProps, 'currentUser' | 'value'> {\n entities: { id: string; projectName: string }[]\n entityType: string\n onWatchersUpdate?: (added: any[], removed: any[]) => void\n userName: string\n}\n\nexport const Watchers = forwardRef<DropdownRef, WatchersProps>(\n ({ entities, entityType, onWatchersUpdate, userName, ...props }, ref) => {\n const entitiesQuery = entities.map((entity) => ({\n entityId: entity.id,\n entityType,\n projectName: entity.projectName,\n }))\n\n const { data: watchers = [] } = useGetEntitiesWatchersQuery(\n {\n entities: entitiesQuery,\n },\n { skip: !entities.length },\n )\n\n // merge all watchers into a single unique array\n const uniqueWatchers = Array.from(new Set(watchers.flatMap((watcher) => watcher.watchers)))\n\n const [setEntitiesWatchers] = useSetEntitiesWatchersMutation()\n\n const handleChange = async (value: string[]) => {\n // find the difference between the current watchers and the new watchers\n // which users were added and which were removed\n const added = value.filter((watcher) => !uniqueWatchers.includes(watcher))\n const removed = uniqueWatchers.filter((watcher) => !value.includes(watcher))\n\n // for each entity, add or remove the watchers\n // we do this to preserve the unique watchers for each entity (rather than setting the same watchers for all entities)\n const updatedEntities = watchers.map((entity) => {\n // first remove\n const newWatchers = entity.watchers.filter((watcher) => !removed.includes(watcher))\n // then add\n newWatchers.push(...added)\n\n return {\n ...entity,\n watchers: newWatchers,\n }\n })\n\n // update\n try {\n await setEntitiesWatchers({ entities: updatedEntities }).unwrap()\n onWatchersUpdate && onWatchersUpdate(added, removed)\n } catch (error) {\n toast.error('Failed to update watchers')\n }\n }\n\n return (\n <WatcherSelect\n align=\"right\"\n {...props}\n value={uniqueWatchers}\n currentUser={userName}\n onChange={handleChange}\n ref={ref}\n // @ts-expect-error\n buttonProps={{ 'data-tooltip': 'Watchers' }}\n />\n )\n },\n)\n"],"names":["jsx"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAYO,MAAM,WAAW;AAAA,EACtB,CAAC,EAAE,UAAU,YAAY,kBAAkB,UAAU,GAAG,MAAM,GAAG,QAAQ;AACvE,UAAM,gBAAgB,SAAS,IAAI,CAAC,YAAY;AAAA,MAC9C,UAAU,OAAO;AAAA,MACjB;AAAA,MACA,aAAa,OAAO;AAAA,IAAA,EACpB;AAEF,UAAM,EAAE,MAAM,WAAW,CAAA,EAAO,IAAA;AAAA,MAC9B;AAAA,QACE,UAAU;AAAA,MACZ;AAAA,MACA,EAAE,MAAM,CAAC,SAAS,OAAO;AAAA,IAC3B;AAGA,UAAM,iBAAiB,MAAM,KAAK,IAAI,IAAI,SAAS,QAAQ,CAAC,YAAY,QAAQ,QAAQ,CAAC,CAAC;AAEpF,UAAA,CAAC,mBAAmB,IAAI,+BAA+B;AAEvD,UAAA,eAAe,OAAO,UAAoB;AAGxC,YAAA,QAAQ,MAAM,OAAO,CAAC,YAAY,CAAC,eAAe,SAAS,OAAO,CAAC;AACnE,YAAA,UAAU,eAAe,OAAO,CAAC,YAAY,CAAC,MAAM,SAAS,OAAO,CAAC;AAI3E,YAAM,kBAAkB,SAAS,IAAI,CAAC,WAAW;AAEzC,cAAA,cAAc,OAAO,SAAS,OAAO,CAAC,YAAY,CAAC,QAAQ,SAAS,OAAO,CAAC;AAEtE,oBAAA,KAAK,GAAG,KAAK;AAElB,eAAA;AAAA,UACL,GAAG;AAAA,UACH,UAAU;AAAA,QACZ;AAAA,MAAA,CACD;AAGG,UAAA;AACF,cAAM,oBAAoB,EAAE,UAAU,gBAAiB,CAAA,EAAE,OAAO;AAC5C,4BAAA,iBAAiB,OAAO,OAAO;AAAA,eAC5C,OAAO;AACd,cAAM,MAAM,2BAA2B;AAAA,MAAA;AAAA,IAE3C;AAGE,WAAAA,kCAAA;AAAA,MAAC;AAAA,MAAA;AAAA,QACC,OAAM;AAAA,QACL,GAAG;AAAA,QACJ,OAAO;AAAA,QACP,aAAa;AAAA,QACb,UAAU;AAAA,QACV;AAAA,QAEA,aAAa,EAAE,gBAAgB,WAAW;AAAA,MAAA;AAAA,IAC5C;AAAA,EAAA;AAGN;"}
|
|
@@ -72,6 +72,7 @@ require("../../api/queries/userDashboard/getUserDashboard.cjs.js");
|
|
|
72
72
|
require("../../api/queries/users/getUsers.cjs.js");
|
|
73
73
|
require("../../api/queries/users/updateUsers.cjs.js");
|
|
74
74
|
require("../../api/queries/watchers/getWatchers.cjs.js");
|
|
75
|
+
require("../../api/queries/permissions/getPermissions.cjs.js");
|
|
75
76
|
require("@dnd-kit/core");
|
|
76
77
|
require("@dnd-kit/sortable");
|
|
77
78
|
require("../../components/ReviewablesList/ReviewablesList.styled.cjs.js");
|
|
@@ -88,6 +89,8 @@ require("../../context/SettingsPanelContext.cjs.js");
|
|
|
88
89
|
require("../../context/pip/PiPProvider.cjs.js");
|
|
89
90
|
require("react-dom");
|
|
90
91
|
require("../../context/pip/PiPWrapper.cjs.js");
|
|
92
|
+
require("../../context/AddonProjectContext.cjs.js");
|
|
93
|
+
require("../../context/AddonContext.cjs.js");
|
|
91
94
|
require("../../components/ReviewableCard/ReviewableCard.cjs.js");
|
|
92
95
|
require("../../components/ReviewableProgressCard/ReviewableProgressCard.styled.cjs.js");
|
|
93
96
|
require("../../components/FileThumbnail/FileThumbnail.cjs.js");
|
|
@@ -130,6 +133,7 @@ require("../ProjectTreeTable/context/ColumnSettingsContext.cjs.js");
|
|
|
130
133
|
require("../ProjectTreeTable/context/CellEditingContext.cjs.js");
|
|
131
134
|
require("../ProjectTreeTable/context/ClipboardContext.cjs.js");
|
|
132
135
|
require("../ProjectTreeTable/context/ProjectTableSelectionContext.cjs.js");
|
|
136
|
+
require("../ProjectTreeTable/context/ProjectDataContext.cjs.js");
|
|
133
137
|
require("@tanstack/react-table");
|
|
134
138
|
require("../ProjectTreeTable/widgets/CollapsedWidget.cjs.js");
|
|
135
139
|
require("../ProjectTreeTable/widgets/DateWidget.cjs.js");
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ActionConfigDialog.cjs.js","sources":["../../../../../src/containers/Actions/ActionConfigDialog.tsx"],"sourcesContent":["import { useMemo } from 'react'\nimport { toast } from 'react-toastify'\nimport { SimpleFormDialog } from '@shared/components'\nimport type { SimpleFormValueDict } from '@shared/components'\n\nimport { useGetActionConfigQuery, useSetActionConfigMutation } from '@shared/api'\nimport type { ActionContext, BaseActionManifest } from '@shared/api'\n\ntype ConfigData = Record<string, any>\n\ninterface ActionConfigDialogProps {\n action: BaseActionManifest\n context: ActionContext\n onClose: () => void\n}\n\ninterface ActionConfigRequestQueryParams {\n addonName: string\n addonVersion: string\n variant?: string\n identifier: string\n}\n\nexport const ActionConfigDialog = ({ action, onClose, context }: ActionConfigDialogProps) => {\n const requestParams: ActionConfigRequestQueryParams | null =\n useMemo<ActionConfigRequestQueryParams | null>(() => {\n if (!action) return null\n if (!(action.addonName && action.addonVersion)) return null // this should never happen\n return {\n addonName: action.addonName,\n addonVersion: action.addonVersion,\n variant: action.variant,\n identifier: action.identifier,\n }\n }, [action])\n\n const [configureAction] = useSetActionConfigMutation()\n\n // make typescript happily unknowing about the type\n // because even if we pass skip, arguments are still required in the right type. that's cursed\n const qp: any = { actionConfig: context, ...(requestParams || {}) }\n const { data: initValues } = useGetActionConfigQuery(qp, { skip: !requestParams })\n\n // it would be sooo cool if i could do this BEFORE the query and ommit that\n // qp thing, but i can't. because it would change the hook order. ffs\n if (!(initValues && action?.configFields && action && requestParams)) {\n return null\n }\n\n const handleSubmit = async (data: ConfigData) => {\n try {\n await configureAction({\n actionConfig: { ...context, value: data },\n ...requestParams,\n }).unwrap()\n onClose()\n } catch (error) {\n console.warn('Error configuring action', error)\n toast.error('Unable to set the action configuration')\n }\n }\n\n return (\n <SimpleFormDialog\n isOpen\n title={`Configure action ${action.label}`}\n fields={action.configFields}\n values={initValues as SimpleFormValueDict}\n onClose={onClose}\n onSubmit={handleSubmit}\n submitLabel=\"Save action config\"\n cancelLabel=\"Cancel\"\n submitIcon=\"check\"\n cancelIcon=\"close\"\n />\n )\n}\n"],"names":["useMemo","useSetActionConfigMutation","useGetActionConfigQuery","toast","jsx","SimpleFormDialog"],"mappings":"
|
|
1
|
+
{"version":3,"file":"ActionConfigDialog.cjs.js","sources":["../../../../../src/containers/Actions/ActionConfigDialog.tsx"],"sourcesContent":["import { useMemo } from 'react'\nimport { toast } from 'react-toastify'\nimport { SimpleFormDialog } from '@shared/components'\nimport type { SimpleFormValueDict } from '@shared/components'\n\nimport { useGetActionConfigQuery, useSetActionConfigMutation } from '@shared/api'\nimport type { ActionContext, BaseActionManifest } from '@shared/api'\n\ntype ConfigData = Record<string, any>\n\ninterface ActionConfigDialogProps {\n action: BaseActionManifest\n context: ActionContext\n onClose: () => void\n}\n\ninterface ActionConfigRequestQueryParams {\n addonName: string\n addonVersion: string\n variant?: string\n identifier: string\n}\n\nexport const ActionConfigDialog = ({ action, onClose, context }: ActionConfigDialogProps) => {\n const requestParams: ActionConfigRequestQueryParams | null =\n useMemo<ActionConfigRequestQueryParams | null>(() => {\n if (!action) return null\n if (!(action.addonName && action.addonVersion)) return null // this should never happen\n return {\n addonName: action.addonName,\n addonVersion: action.addonVersion,\n variant: action.variant,\n identifier: action.identifier,\n }\n }, [action])\n\n const [configureAction] = useSetActionConfigMutation()\n\n // make typescript happily unknowing about the type\n // because even if we pass skip, arguments are still required in the right type. that's cursed\n const qp: any = { actionConfig: context, ...(requestParams || {}) }\n const { data: initValues } = useGetActionConfigQuery(qp, { skip: !requestParams })\n\n // it would be sooo cool if i could do this BEFORE the query and ommit that\n // qp thing, but i can't. because it would change the hook order. ffs\n if (!(initValues && action?.configFields && action && requestParams)) {\n return null\n }\n\n const handleSubmit = async (data: ConfigData) => {\n try {\n await configureAction({\n actionConfig: { ...context, value: data },\n ...requestParams,\n }).unwrap()\n onClose()\n } catch (error) {\n console.warn('Error configuring action', error)\n toast.error('Unable to set the action configuration')\n }\n }\n\n return (\n <SimpleFormDialog\n isOpen\n title={`Configure action ${action.label}`}\n fields={action.configFields}\n values={initValues as SimpleFormValueDict}\n onClose={onClose}\n onSubmit={handleSubmit}\n submitLabel=\"Save action config\"\n cancelLabel=\"Cancel\"\n submitIcon=\"check\"\n cancelIcon=\"close\"\n />\n )\n}\n"],"names":["useMemo","useSetActionConfigMutation","useGetActionConfigQuery","toast","jsx","SimpleFormDialog"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAuBO,MAAM,qBAAqB,CAAC,EAAE,QAAQ,SAAS,cAAuC;AACrF,QAAA,gBACJA,MAAAA,QAA+C,MAAM;AAC/C,QAAA,CAAC,OAAe,QAAA;AACpB,QAAI,EAAE,OAAO,aAAa,OAAO,cAAsB,QAAA;AAChD,WAAA;AAAA,MACL,WAAW,OAAO;AAAA,MAClB,cAAc,OAAO;AAAA,MACrB,SAAS,OAAO;AAAA,MAChB,YAAY,OAAO;AAAA,IACrB;AAAA,EAAA,GACC,CAAC,MAAM,CAAC;AAEP,QAAA,CAAC,eAAe,IAAIC,sCAA2B;AAIrD,QAAM,KAAU,EAAE,cAAc,SAAS,GAAI,iBAAiB,CAAA,EAAI;AAC5D,QAAA,EAAE,MAAM,eAAeC,WAAAA,wBAAwB,IAAI,EAAE,MAAM,CAAC,eAAe;AAIjF,MAAI,EAAE,eAAc,iCAAQ,iBAAgB,UAAU,gBAAgB;AAC7D,WAAA;AAAA,EAAA;AAGH,QAAA,eAAe,OAAO,SAAqB;AAC3C,QAAA;AACF,YAAM,gBAAgB;AAAA,QACpB,cAAc,EAAE,GAAG,SAAS,OAAO,KAAK;AAAA,QACxC,GAAG;AAAA,MACJ,CAAA,EAAE,OAAO;AACF,cAAA;AAAA,aACD,OAAO;AACN,cAAA,KAAK,4BAA4B,KAAK;AAC9CC,oBAAA,MAAM,MAAM,wCAAwC;AAAA,IAAA;AAAA,EAExD;AAGE,SAAAC,2BAAA,kBAAA;AAAA,IAACC,iBAAA;AAAA,IAAA;AAAA,MACC,QAAM;AAAA,MACN,OAAO,oBAAoB,OAAO,KAAK;AAAA,MACvC,QAAQ,OAAO;AAAA,MACf,QAAQ;AAAA,MACR;AAAA,MACA,UAAU;AAAA,MACV,aAAY;AAAA,MACZ,aAAY;AAAA,MACZ,YAAW;AAAA,MACX,YAAW;AAAA,IAAA;AAAA,EACb;AAEJ;;"}
|