diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml new file mode 100644 index 00000000..58f9e185 --- /dev/null +++ b/.github/workflows/build.yml @@ -0,0 +1,64 @@ +name: Build Container Image +on: + workflow_dispatch: + push: + branches: + - main + tags: + - "*" +jobs: + build: + name: Build + runs-on: ubuntu-latest + + strategy: + matrix: + arch: [amd64, arm64] + + permissions: + packages: write + + steps: + - name: Checkout Entire Repository + uses: actions/checkout@v4 + + - name: Set up QEMU + uses: docker/setup-qemu-action@v3 + + - name: Set up Docker Buildx + uses: docker/setup-buildx-action@v3 + with: + platforms: linux/${{ matrix.arch }} + - name: Login to GitHub Container Registry + uses: docker/login-action@v2 + with: + registry: ghcr.io + username: ${{ github.actor }} + password: ${{ secrets.GITHUB_TOKEN }} + + - name: Set Branch + run: | + export APPS_JSON='[{"url": "https://github.com/frappe/lms","branch": "main"}]' + echo "APPS_JSON_BASE64=$(echo $APPS_JSON | base64 -w 0)" >> $GITHUB_ENV + echo "FRAPPE_BRANCH=version-15" >> $GITHUB_ENV + + - name: Set Image Tag + run: | + echo "IMAGE_TAG=stable" >> $GITHUB_ENV + - uses: actions/checkout@v4 + with: + repository: frappe/frappe_docker + path: builds + + - name: Build and push + uses: docker/build-push-action@v6 + with: + push: true + context: builds + file: builds/images/layered/Containerfile + tags: > + ghcr.io/${{ github.repository }}:${{ github.ref_name }}, + ghcr.io/${{ github.repository }}:${{ env.IMAGE_TAG }} + build-args: | + "FRAPPE_BRANCH=${{ env.FRAPPE_BRANCH }}" + "APPS_JSON_BASE64=${{ env.APPS_JSON_BASE64 }}" \ No newline at end of file diff --git a/README.md b/README.md index 6b06f476..6c0989b9 100644 --- a/README.md +++ b/README.md @@ -106,9 +106,9 @@ wget https://frappe.io/easy-install.py python3 ./easy-install.py deploy \ --project=learning_prod_setup \ --email=your_email.example.com \ - --image=ghcr.io/frappe/learning \ + --image=ghcr.io/frappe/lms \ --version=stable \ - --app=learning \ + --app=lms \ --sitename subdomain.domain.tld ``` diff --git a/frontend/src/utils/markdownParser.js b/frontend/src/utils/markdownParser.js index 1303d1a7..db47283c 100644 --- a/frontend/src/utils/markdownParser.js +++ b/frontend/src/utils/markdownParser.js @@ -18,6 +18,27 @@ export class Markdown { } } + onPaste(event) { + const data = { + text: event.detail.data.innerHTML, + } + + this.data = data + + window.requestAnimationFrame(() => { + if (!this.wrapper) { + return + } + this.wrapper.innerHTML = this.data.text || '' + }) + } + + static get pasteConfig() { + return { + tags: ['P'], + } + } + render() { this.wrapper = document.createElement('div') this.wrapper.classList.add('cdx-block') @@ -36,10 +57,6 @@ export class Markdown { this.parseContent(event) } }) - - this.wrapper.addEventListener('paste', (event) => - this.handlePaste(event) - ) } return this.wrapper @@ -101,19 +118,6 @@ export class Markdown { this.api.caret.focus(true) } - handlePaste(event) { - event.preventDefault() - - const clipboardData = event.clipboardData || window.clipboardData - const pastedText = clipboardData.getData('text/plain') - const sanitizedText = this.processPastedContent(pastedText) - document.execCommand('insertText', false, sanitizedText) - } - - processPastedContent(text) { - return text.trim() - } - save(blockContent) { return { text: blockContent.innerHTML,