import React from "react";
import PropTypes from "prop-types";
import { Link } from "react-router-dom";
import { URL_FILES } from "../helpers/";
import { NgIf, Icon, EventEmitter } from "./";
import ReactCSSTransitionGroup from "react-addons-css-transition-group";
import "./breadcrumb.scss";
export class BreadCrumb extends React.Component {
    constructor(props) {
        super(props);
        this.state = {
            path: this._formatPath(props.path),
        };
    }
    UNSAFE_componentWillReceiveProps(props) {
        this.setState({ path: this._formatPath(props.path) });
    }
    _formatPath(full_path) {
        let paths = full_path.split("/");
        if (paths.slice(-1)[0] === "") {
            paths.pop();
        }
        paths = paths.map((path, index) => {
            const sub_path = paths.slice(0, index+1).join("/");
            const label = path === "" ? (CONFIG.name || "Filestash") : path;
            if (index === paths.length - 1) {
                return { full: null, label: label };
            } else {
                return {
                    full: sub_path + "/",
                    label: label,
                    minify: function() {
                        if (index === 0) {
                            return false;
                        }
                        if (paths.length <= (document.body.clientWidth > 800 ? 5 : 4)) {
                            return false;
                        }
                        if (index > paths.length - (document.body.clientWidth > 1000? 4 : 3)) {
                            return false;
                        }
                        return true;
                    }(),
                };
            }
        });
        return paths;
    }
    render(Element) {
        if (new window.URL(location.href).searchParams.get("nav") === "false") return null;
        const Path = Element? Element : PathElement;
        return (
            
                
                     
                    
                        {
                            this.state.path.map((path, index) => {
                                return (
                                     
                                );
                            })
                        }
                     
                 
             
        );
    }
};
BreadCrumb.propTypes = {
    path: PropTypes.string.isRequired,
    needSaving: PropTypes.bool,
};
const BreadCrumbContainer = (props) => {
    return (
        
    );
};
const Logout = (props) => {
    const isRunningFromAnIframe = window.self !== window.top;
    return (
        
            {
                isRunningFromAnIframe ? null : (
                     
                         
                    
                )
            }
        
    );
};
const Saving = (props) => {
    return (
        
            
                *
             
         
    );
};
const Separator = (props) => {
    /* eslint-disable-next-line max-len */
    const src = "";
    return (
        
    );
};
class PathElementWrapperComponent extends React.Component {
    constructor(props) {
        super(props);
    }
    limitSize(str, is_highlight = false) {
        if (is_highlight === true) {
            if (str.length > 30) {
                return str.substring(0, 12).trim() + "..." +
                    str.substring(str.length - 10, str.length).trim();
            }
        } else {
            if (str.length > 27) {
                return str.substring(0, 20).trim() + "...";
            }
        }
        return str;
    }
    render() {
        let className = "component_path-element-wrapper";
        if (this.props.highlight) {
            className += " highlight";
        }
        let href = this.props.baseURL + (this.props.path.full || "");
        href = href
            .replace(/\%/g, "%2525") // Hack to get the Link Component to work
            // See ExistingThing in 'thing-existing.js'
            .replace(/#/g, "%23")
            .replace(/\?/g, "%3F");
        href = href || "/";
        href += location.search;
        return (
            
                
                     
                        
                            { this.limitSize(this.props.path.label) }
                         
                        
                            ...
                            
                                { this.limitSize(this.props.path.label, true) }
                             
                         
                    
                     
                 
                
                    {this.limitSize(this.props.path.label)}
                     
                 
             
        );
    }
}
export const PathElementWrapper = EventEmitter(PathElementWrapperComponent);
// just a hack to make it play nicely with react-dnd as it refuses to use our
// custom component if it's not wrap by something it knows ...
export class PathElement extends PathElementWrapper {
    constructor(props) {
        super(props);
    }
    render(highlight = false) {
        let className = "component_path-element";
        if (this.props.isFirst) className += ` is-first`;
        if (this.props.className) className += ` ${this.props.className}`;
        return (
            
        );
    }
}