anyone-oslo/pages

View on GitHub

Showing 65 of 130 total issues

Function Grid has 189 lines of code (exceeds 25 allowed). Consider refactoring.
Open

export default function Grid(props: Props) {
const { primary, images, deleted, setDeleted } = props.state;
 
const containerRef = useRef();
const error = useToastStore((state) => state.error);
Severity: Major
Found in app/javascript/components/ImageGrid/Grid.tsx - About 7 hrs to fix

    Function PageTree has a Cognitive Complexity of 38 (exceeds 5 allowed). Consider refactoring.
    Open

    export default function PageTree({ dir, locale, pages, permissions }: Props) {
    const [state, dispatch] = usePageTree(pages, locale, dir, permissions);
     
    const [dragging, setDragging] = useState(false);
    const [dragState, setDragState] = useState<DragState | null>(null);
    Severity: Minor
    Found in app/javascript/components/PageTree.tsx - About 5 hrs to fix

    Function ImageUploader has 132 lines of code (exceeds 25 allowed). Consider refactoring.
    Open

    export default function ImageUploader(props: Props) {
    const [uploading, setUploading] = useState(false);
    const [dragover, setDragover] = useState(false);
    const [state, setState] = useState<State>({
    image: props.image,
    Severity: Major
    Found in app/javascript/components/ImageUploader.tsx - About 5 hrs to fix

      Function Node has 127 lines of code (exceeds 25 allowed). Consider refactoring.
      Open

      export default function Node(props: Props) {
      const { state, dispatch } = usePageTreeContext();
      const { id, dragging, onDragStart } = props;
      const { dir, locale } = state;
      const node = state.nodes[id];
      Severity: Major
      Found in app/javascript/components/PageTree/Node.tsx - About 5 hrs to fix

        Function PageForm has 122 lines of code (exceeds 25 allowed). Consider refactoring.
        Open

        export default function PageForm(props: Props) {
        const [state, dispatch] = usePage({
        locales: props.locales,
        locale: props.locale,
        page: props.page,
        Severity: Major
        Found in app/javascript/components/PageForm.tsx - About 4 hrs to fix

          Function List has 121 lines of code (exceeds 25 allowed). Consider refactoring.
          Open

          export default function List(props: Props) {
          const { collection, deleted, setDeleted } = props.state;
          const locales = props.locales ? Object.keys(props.locales) : [props.locale];
           
          const uploadAttachment = (file: File) => {
          Severity: Major
          Found in app/javascript/components/Attachments/List.tsx - About 4 hrs to fix

            Function Attachment has 98 lines of code (exceeds 25 allowed). Consider refactoring.
            Open

            export default function Attachment(props: Props) {
            const { attributeName, draggable, locales, locale } = props;
            const { record } = draggable;
            const { attachment, uploading } = record;
             
             
            Severity: Major
            Found in app/javascript/components/Attachments/Attachment.tsx - About 3 hrs to fix

              Function ImageUploader has a Cognitive Complexity of 27 (exceeds 5 allowed). Consider refactoring.
              Open

              export default function ImageUploader(props: Props) {
              const [uploading, setUploading] = useState(false);
              const [dragover, setDragover] = useState(false);
              const [state, setState] = useState<State>({
              image: props.image,
              Severity: Minor
              Found in app/javascript/components/ImageUploader.tsx - About 3 hrs to fix

              Function AttachmentEditor has 93 lines of code (exceeds 25 allowed). Consider refactoring.
              Open

              export default function AttachmentEditor(props: Props) {
              const { attachment, locales } = props;
               
              const [locale, setLocale] = useState(props.locale);
              const [localizations, setLocalizations] = useState({
              Severity: Major
              Found in app/javascript/components/Attachments/AttachmentEditor.tsx - About 3 hrs to fix

                Function GridImage has 76 lines of code (exceeds 25 allowed). Consider refactoring.
                Open

                export default function GridImage(props: Props) {
                const { attributeName, draggable } = props;
                const record = draggable.record;
                const image = record.image;
                 
                 
                Severity: Major
                Found in app/javascript/components/ImageGrid/GridImage.tsx - About 3 hrs to fix

                  Function Toolbar has 74 lines of code (exceeds 25 allowed). Consider refactoring.
                  Open

                  export default function Toolbar() {
                  const { state, dispatch } = useImageCropperContext();
                  const { cropping, image } = state;
                   
                  const aspectRatios: Array<[string, Crop.Ratio]> = [
                  Severity: Major
                  Found in app/javascript/components/ImageCropper/Toolbar.tsx - About 2 hrs to fix

                    Function applyTabs has a Cognitive Complexity of 21 (exceeds 5 allowed). Consider refactoring.
                    Open

                    function applyTabs() {
                    const tabLinks: HTMLAnchorElement[] = Array.from(
                    document.querySelectorAll(".content-tabs li a")
                    );
                    const tabs: HTMLDivElement[] = Array.from(
                    Severity: Minor
                    Found in app/javascript/features/contentTabs.ts - About 2 hrs to fix

                    Function drag has 65 lines of code (exceeds 25 allowed). Consider refactoring.
                    Open

                    (e: MouseEvent) => {
                    if (!dragState) {
                    return;
                    } else if (!dragging) {
                    const distance =
                    Severity: Major
                    Found in app/javascript/components/PageTree.tsx - About 2 hrs to fix

                      Function DateRangeSelect has 64 lines of code (exceeds 25 allowed). Consider refactoring.
                      Open

                      export default function DateRangeSelect(props: Props) {
                      const { disabled, disableTime, objectName } = props;
                       
                      const [uncontrolledStartsAt, setUncontrolledStartsAt] = useState(
                      parseDate(props.startsAt)
                      Severity: Major
                      Found in app/javascript/components/DateRangeSelect.tsx - About 2 hrs to fix

                        Function useDragUploader has 62 lines of code (exceeds 25 allowed). Consider refactoring.
                        Open

                        export default function useDragUploader<T>(
                        collections: Drag.Collection<T>[],
                        onDragEnd: (dragState: Drag.State<T>, files: File[]) => void
                        ): [Drag.State<T>, StartDrag<T>, Listeners] {
                        const [dragState, setDragState] = useState<Drag.State<T>>({
                        Severity: Major
                        Found in app/javascript/components/drag/useDragUploader.ts - About 2 hrs to fix

                          Function Attachment has a Cognitive Complexity of 18 (exceeds 5 allowed). Consider refactoring.
                          Open

                          export default function Attachment(props: Props) {
                          const { attributeName, draggable, locales, locale } = props;
                          const { record } = draggable;
                          const { attachment, uploading } = record;
                           
                           
                          Severity: Minor
                          Found in app/javascript/components/Attachments/Attachment.tsx - About 2 hrs to fix

                          Function applyTabs has 58 lines of code (exceeds 25 allowed). Consider refactoring.
                          Open

                          function applyTabs() {
                          const tabLinks: HTMLAnchorElement[] = Array.from(
                          document.querySelectorAll(".content-tabs li a")
                          );
                          const tabs: HTMLDivElement[] = Array.from(
                          Severity: Major
                          Found in app/javascript/features/contentTabs.ts - About 2 hrs to fix

                            Function FocalPoint has 57 lines of code (exceeds 25 allowed). Consider refactoring.
                            Open

                            export default function FocalPoint(props: Props) {
                            const { width, height } = props;
                            const { state, dispatch } = useImageCropperContext();
                             
                            const [dragging, setDragging] = useState(false);
                            Severity: Major
                            Found in app/javascript/components/ImageCropper/FocalPoint.tsx - About 2 hrs to fix

                              Function DateTimeSelect has 56 lines of code (exceeds 25 allowed). Consider refactoring.
                              Open

                              export default function DateTimeSelect(props: Props) {
                              const { name, disabled, disableTime, onChange, value } = props;
                               
                              const [timeString, setTimeString] = useState(timeToString(value));
                               
                               
                              Severity: Major
                              Found in app/javascript/components/DateTimeSelect.tsx - About 2 hrs to fix

                                Function Block has 54 lines of code (exceeds 25 allowed). Consider refactoring.
                                Open

                                export default function Block(props: Props) {
                                const { block, errors, onChange, lang, dir, value } = props;
                                 
                                const handleChange = (
                                evt: ChangeEvent<HTMLInputElement> | ChangeEvent<HTMLSelectElement>
                                Severity: Major
                                Found in app/javascript/components/PageForm/Block.tsx - About 2 hrs to fix
                                  Severity
                                  Category
                                  Status
                                  Source
                                  Language