UNPKG

@ryzeup/richtexteditor

Version:

A React Rich Text Editor component

2 lines (1 loc) 5.47 kB
*{box-sizing:border-box;margin:0}.rte-wrapper{font-family:Inter,system-ui,sans-serif;display:flex;flex-grow:1;flex-direction:row;min-height:400px;min-width:400px;gap:12px;padding:12px;background:#fff;overflow:hidden}.rte-wrapper>div:first-child{display:flex;flex-direction:column;flex:2;min-width:0;min-height:0;gap:8px;overflow:hidden}.rte-toolbar{position:static!important;overflow:visible!important;flex-shrink:0;display:flex;flex-wrap:wrap;align-items:center;gap:10px;background:#fafafa;padding:8px;border:1px solid #eee;border-radius:6px;overflow-y:auto;max-height:140px;user-select:none}.rte-dropdown{padding:4px 8px;border-radius:4px;border:1px solid #ccc;font-size:12px;background:#fff;cursor:pointer;width:110px}.rte-fontsize-dropdown{max-height:80px;overflow-y:scroll}.rte-toolbar button{padding:6px;border:1px solid transparent;background:none;cursor:pointer}.rte-toolbar button:hover{color:#00f}.rte-toolbar button[title=Emoji]{color:#ff0;fill:#000;background:none;font-size:18px;display:inline-flex;align-items:center;justify-content:center;border:none}.rte-toolbar button[title=Emoji] svg{background-color:#000;border-radius:50%;display:block}.rte-toolbar button[title=removeFormat]{font-size:16px}.rte-toolbar *{user-select:none;pointer-events:auto}.rte-editor{flex:1 1 auto;min-height:0;padding:12px;outline:none;border:1px solid lightgray;border-radius:4px;background:#fff;overflow-y:auto}.rte-output{flex-shrink:0;height:20%;background:#f7f7f7;border:1px solid lightgray;border-radius:4px;padding:10px;overflow-y:auto;min-height:100px}.rte-output h4{margin-bottom:6px;font-size:14px}.rte-preview{flex:1;border:1px solid #ccc;border-radius:4px;background:#fff;padding:10px;overflow-y:auto;min-width:200px;min-height:200px}.rte-editor table,.rte-preview table{border-collapse:collapse;width:100%}.rte-editor th,.rte-editor td,.rte-preview th,.rte-preview td{border:1px solid #ccc;background:#fff;padding:6px;min-width:60px;position:relative}.rte-editor th,.rte-preview th{background-color:#d3d3d3}.rte-th div,.rte-td div{border:none!important;background:transparent!important;padding:0;margin:0}.rte-cell-highlight{outline:2px solid #007bff;outline-offset:-2px;background-color:#007bff1a;z-index:2}.rte-popup{position:fixed;padding:4px 0;background-color:#fff;border:1px solid lightgray;border-radius:4px;box-shadow:0 2px 6px #0000001a;list-style:none;margin:0;z-index:1000;max-height:250px;overflow-y:auto;width:fit-content}.rte-emoji-popup{position:fixed;top:130%;left:25%;background:#fff;border:1px solid #ccc;border-radius:8px;padding:8px;width:260px;height:200px;overflow-y:auto;display:grid;grid-template-columns:repeat(6,1fr);gap:4px;z-index:10000;box-shadow:0 4px 8px #00000026}.rte-table-menu{position:absolute;display:flex;flex-direction:column;align-items:baseline;gap:4px;background:#fff;border:1px solid #ccc;box-shadow:0 2px 6px #00000026;z-index:999;padding:4px}.rte-table-menu button{display:flex;align-items:end;gap:4px;padding:6px;border:1px solid transparent;background:none;cursor:pointer}.rte-table-menu button:hover{color:#00f}.rte-link-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0006;z-index:9999;backdrop-filter:blur(1px)}.rte-link-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border:1px solid #ccc;border-radius:6px;box-shadow:0 4px 8px #0003;padding:16px;width:320px;z-index:10000;animation:fadeIn .2s ease-in-out}.rte-link-modal__title{margin-bottom:8px;font-size:16px;font-weight:600;text-align:center}.rte-link-modal__input,.rte-link-modal__select{width:100%;padding:6px 8px;margin-bottom:8px;border:1px solid #ccc;border-radius:4px;font-size:14px}.rte-link-modal__input:focus,.rte-link-modal__select:focus{border-color:#007bff;outline:none}.rte-link-modal__actions{display:flex;justify-content:flex-end;gap:8px}.rte-link-modal__btn{padding:6px 12px;border:none;border-radius:4px;font-size:14px;cursor:pointer}.rte-link-modal__btn:hover{opacity:.9}.rte-link-modal__btn--ok{background:#007bff;color:#fff}@keyframes fadeIn{0%{opacity:0;transform:translate(-50%,-48%)}to{opacity:1;transform:translate(-50%,-50%)}}.rte-toolbar{border:1px solid #e0e0e0;transition:box-shadow .2s ease}.rte-toolbar button:hover{background:#eef3ff;border-radius:6px;color:#007bff;transform:translateY(-2px);transition:all .2s ease}.rte-editor{border:1px solid #ddd;border-radius:2px;background:#fcfcfc;padding:16px;line-height:1.6;font-size:12px;transition:all .2s ease}.rte-editor:focus{border-color:#007bff;background:#fff}.rte-output{border:1px solid #e5e8ec;font-family:monospace;font-size:13px;color:#333}.rte-preview{background:#fff;border:1px solid #e5e5e5;border-radius:10px;box-shadow:0 2px 6px #0000000d;padding:16px}.rte-emoji-popup{background:#fff;box-shadow:0 4px 12px #00000026;padding:10px;width:280px;grid-template-columns:repeat(7,1fr);gap:6px}.rte-emoji-popup span{font-size:22px;cursor:pointer;transition:transform .15s ease}.rte-emoji-popup span:hover{transform:scale(1.3)}.rte-inserted-image{max-width:100%;height:200px;width:fit-content;object-fit:cover;border-radius:6px;display:inline-block;vertical-align:middle;box-shadow:0 1px 4px #0000000f;transition:box-shadow .15s ease,transform .15s ease;cursor:pointer;position:relative}.rte-inserted-image:hover{box-shadow:0 4px 14px #0000001f;transform:translateY(-1px)}.rte-highlight{color:#007bff;font-weight:700;font-weight:600}.rte-active{background:#dce8ff!important;border-radius:4px!important}